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GRAPHICS DISPLAY SYSTEM 
CROSS-REFERENCE TO RELATED APPLICATIONS 

5 This application claims the benefit of the filing date of 

U.S. provisional patent application number 60/107,875, filed 
November 9, 1998 and entitled "Graphics Chip Architecture." 

FIELD OF THE INVENTION 

10 

The present invention relates generally to integrated 
circuits, and more particularly to an integrated circuit graphics 
display system for processing and displaying video and graphics. 

15 BACKGROUND OF THE INVENTION 

Graphics display systems are typically used in television 
control electronics, such as set top boxes, integrated digital 
TVs, and home network computers. Graphics display systems 

20 typically include a display engine that may perform display 
functions. The display engine is the part of the graphics 
display system that receives display pixel data from any 
combination of locally attached video and graphics input ports, 
processes the data in some way, and produces final display pixels 

25 as output. 

This application includes references to both graphics and 
video, which reflects in certain ways the structure of the 
hardware itself. This split does not, however, imply the 
30 existence of any fundamental difference between graphics and 
video, and in fact much of the functionality is common to both. 
Graphics as used herein may include graphics, text and video. 
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SUMMARY OF THE INVENTION 

A graphics display system receives graphics and video, and 
provides output that contains blended graphics and video for 
5 display. The system includes a display engine that processes the 
graphics data and a video compositor that composites the graphics 
data and video data to produce the blended output. The system may 
spatially process the graphics data independently of the video data 
prior to blending. 

10 

In alternate embodiments, the system may include one or more 
of the following features: 

The system may use data structures called window descriptors 
15 to characterize logical surfaces, or windows, of graphics content 
for display on a screen. Each window descriptor may contain one or 
more parameters that describe a corresponding window. The window 
descriptors allow graphics windows to be layered over and blended 
with other graphics windows using an alpha value per window or an 
20 alpha value per pixel or both. 

A graphics window control data passing mechanism preferably 
manages the graphics display and compositing functions. The 
mechanism may coordinate the packaging of window display parameters 
25 into header packets and graphics data into data packets, and the 
transferring of the header packets and data packets to a display 
engine . 

A color look-up (CLUT) table loading mechanism preferably 
30 facilitates the transfer of real-time CLUT table data during 
graphics composition. The loading mechanism may be triggered by a 
window descriptor that contains a color look-up table load command. 

2 
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The system may incorporate a graphics line buffer control 
scheme that allows composition of graphics data one line at a time 
using line buffers, and manages line buffer usage in different 
5 clock domains. The line buffers may help save memory, since the 
system, in this embodiment, does not require a frame buffer to 
store the display information produced as a result of combining 
different graphics windows. 

10 A soft horizontal scrolling mechanism preferably enables 

placement of the contents of graphics windows on arbitrary 
positions on a display line. By blanking out one or more pixels 
aligned to the start address, the content of a graphics window may 
be shifted to the left. By accessing graphics data of an address 

15 just prior to the start address and blanking out one or more pixels 
aligned to that address, the content of a graphics window may be 
shifted to the right. 

The system may use anti-aliased text and graphics to provide 
20 high quality display of graphical elements, or glyphs, which 
represent an image of a character of text or graphics, on 
television and other displays. The graphical elements may be 
superimposed over live video or arbitrary graphics imagery. 

25 The system may also eliminate or reduce the interlace flutter 

effect without requiring an anti-flutter filter in the display 
process, thereby preferably reducing the hardware and memory 
bandwidth required . 

30 The system may include a video decoder having a chroma-locked 

sample rate converter. The chroma-locked sample rate converter 
preferably converts the samples to those taken at a sample rate 

3 
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35721/SAH/B600 

that is a multiple of the chroma subcarrier frequency and that is 
locked to chroma bursts of the analog video signal in a control 
loop. Alternatively, the sample conversion rate may remain 
constant while the sampling rate is adjusted in the control loop. 

5 

The video decoder preferably also includes a line-locked 
sample rate converter that receives samples at a multiple of the 
chroma subcarrier frequency and converts the samples to samples 
with a sample frequency that is a multiple of the horizontal line 

10 rate of the video input. The line-locked sample rate converter 
preferably measures the horizontal line rate to an accuracy of a 
fraction of a pixel and adjusts the sample rate and phase of the 
line-locked sample rate converter to produce accurate line-locked 
samples. The time base corrector may receive samples at the output 

15 of the line-locked sample rate converter and may provide samples 
synchronized to the display clock for - reducing undesirable 
artifacts such as jitter. 



A video scaling system preferably conserves memory by 
20 downscaling video prior to capturing the video in memory and 
upscaling video after the video is called out of memory. 



The display engine preferably blends graphics images arranged 
in graphics windows using alpha values for the windows, alpha 
25 values per pixel, or both. The system preferably calculates a 
composite alpha value based on the window' s alpha values and the 
alpha values per pixel. Blended graphics may then be composited 
with video using the composite alpha value. 



30 The system preferably includes a single polyphase filter that 

preferably provides both anti-flutter filtering and scaling of 
graphics. Anti-flutter filtering may help reduce display flicker 

4 
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due to the interlaced nature of television displays. The scaling 
of graphics may be used to convert the normally square pixel aspect 
ratio of graphics to the normally rectangular pixel aspect ratio of 
video • 

5 

The system may incorporate a unified memory architecture that 
is shared by the graphics display system, a CPU, and other 
peripherals. The unified memory architecture preferably uses real 
time scheduling to service tasks. Critical instant analysis may be 
10 used to find a schedule for memory usage that does not affect 
memory requirements of real time tasks while at the same time 
servicing non-real-time tasks as needed. 

The system may employ a graphics accelerator that includes 
15 memory for graphics data. The accelerator preferably includes a 
coprocessor for performing vector type operations on a plurality of 
components of one pixel of the graphics data. The accelerator may 
also have an expanded instruction set for storing and loading data. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a block diagram of an integrated circuit graphics 
display system according to a presently preferred embodiment of the 
5 invention; 

FIG. 2 is a block diagram of certain functional blocks of the 
system; 

FIG. 3 is a block diagram of an alternate embodiment of the 
system of FIG. 2 that incorporates an on-chip I/O bus; 
10 FIG. 4 is a functional block diagram of exemplary video and 

graphics display pipelines; 

FIG. 5 is a more detailed block diagram of the graphics and 
video pipelines of the system; 

FIG. 6 is a map of an exemplary window descriptor for 
15 describing graphics windows and solid surfaces; 

FIG. 7 is a flow diagram of an exemplary process for sorting 
window descriptors in a window controller; 

FIG. 8 is a flow diagram of a graphics window control data 
passing mechanism and a color look-up table loading mechanism; 
20 FIG. 9 is a state diagram of a state machine in a graphics 

converter that may be used during processing of header packets; 

FIG. 10 is a block diagram of an embodiment of a display 
engine; 

FIG. 11 is a block diagram of an embodiment of a color look-up 
25 table (CLUT) ; 

FIG. 12 is a timing diagram of signals that may be used to 
load a CLUT; 

FIG. 13 is a block diagram illustrating exemplary graphics 
line buffers; 

30 FIG. 14 is a flow diagram of a system for controlling the 

graphics line buffers of FIG. 13; 

FIG. 15 is a representation of left scrolling using a window 
soft horizontal scrolling mechanism; 

FIG. 16 is a representation of right scrolling using a window 
35 soft horizontal scrolling mechanism; 

6 
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FIG. 17 is a flow diagram illustrating a system that uses 
graphics elements or glyphs for anti-aliased text and graphics 
applications ; 

FIG. 18 is a block diagram of certain functional blocks of a 
5 video decoder for performing video synchronization; 

FIG. 19 is a block diagram of an embodiment of a chroma-locked 
sample rate converter (SRC) ; 

FIG. 20 is a block diagram of an alternate embodiment of the 
chroma-locked SRC of FIG. 19; 
10 FIG. 21 is a block diagram of an exemplary line-locked SRC; 

FIG. 22 is a block diagram of an exemplary time base corrector 
(TBC) ; 

FIG. 23 is a flow diagram of a process that employs a TBC to 
synchronize an input video to a display clock; 
15 FIG. 24 is a flow diagram of a process for video scaling in 

which downscaling is performed prior to capture of video in memory 
and upscaling is performed after reading video data out of memory; 

FIG. 25 is a detailed block diagram of components used during 
video scaling with signal paths involved in downscaling; 
20 FIG. 26 is a detailed block diagram of components used during 

video scaling with signal paths involved in upscaling; 

FIG. 27 is a detailed block diagram of components that may be 
used during video scaling with signal paths indicated for both 
upscaling and downscaling; 
25 FIG. 28 is a flow diagram of an exemplary process for blending 

graphics and video surfaces; 

FIG. 29 is a flow diagram of an exemplary process for blending 
graphics windows into a combined blended graphics output; 

FIG. 30 is a flow diagram of an exemplary process for blending 
30 graphics, video and background color; 

FIG. 31 is a block diagram of a polyphase filter that performs 
both anti-flutter filtering and vertical scaling of graphics 
windows; 

FIG. 32 is a functional block diagram of an exemplary memory 
35 service request and handling -system with dual memory controllers; 
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FIG. 33 is a functional block diagram of an implementation of 
a real time scheduling system; 

FIG. 34 is a timing diagram of an exemplary CPU servicing 
mechanism that has been implemented using real time scheduling; 
5 FIG. 35 is a timing diagram that illustrates certain 

principles of critical instant analysis for an implementation of 
real time scheduling; 

FIG. 36 is a flow diagram illustrating servicing of requests 
according to the priority of the task; and 
10 FIG. 37 is a block diagram of a graphics accelerator, which 

may be coupled to a CPU and a memory controller. 
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DETAILED DESCRIPTION OF A PRESENTLY PREFERRED EMBODIMENT 
I. Graphics Display System Architecture 

5 Referring to FIG. 1, the graphics display system according to 

the present invention is preferably contained in an integrated 
circuit 10. The integrated circuit may include inputs 12 for 
receiving video signals 14, a bus 20 for connecting to a CPU 22, a 
bus 24 for transferring data to and from memory 28, and an output 
10 30 for providing a video output signal 32. The system may further 
include an input 26 for receiving audio input 34 and an output 27 
for providing audio output 36. 

The graphic display system accepts video input signals that 
15 may include analog video signals, digital video signals, or both. 
The analog signals may be, for example, NTSC, PAL and SECAM signals 
or any other conventional type of analog signal. The digital 
signals may be in the form of decoded MPEG signals or other format 
of digital video. In an alternate embodiment, the system includes 
20 an on-chip decoder for decoding the MPEG or other digital video 
signals input to the system. Graphics data for display is produced 
by any suitable graphics library software, such as Direct Draw 
marketed by Microsoft Corporation, and is read from the CPU 22 into 
the memory 28. The video output signals 32 may be analog signals, 
25 such as composite NTSC, PAL, Y/C (S-video), SECAM or other signals 
that include video and graphics information. In an alternate 
embodiment, the system provides serial digital video output to an 
on-chip or off-chip serializer that may encrypt the output. 

30 The graphics display system memory 28 is preferably a unified 

synchronous dynamic random access memory (SDRAM) that is shared by 
the system, the CPU 22 and other peripheral components. In the 
preferred embodiment the CPU uses the unified memory for its code 
and data while the graphics display system performs all graphics, 

35 video and audio functions assigned to it by software. The amount 
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of memory and CPU performance are preferably tunable by the system 
designer for the desired mix of performance and memory cost. In 
the preferred embodiment, a set-top box is implemented with SDRAM 
that supports both the CPU and graphics. 

5 

Referring to FIG. 2, the graphics display system preferably 
includes a video decoder 50, video scaler 52, memory controller 54, 
window controller 56, display engine 58, video compositor 60, and 
video encoder 62. The system, may optionally include a graphics 

10 accelerator 64 and an audio engine 66. The system may display 
graphics, passthrough video, scaled video or a combination of the 
different types of video and graphics. Passthrough video includes 
digital or analog video that is not captured in memory. The 
passthrough video may be selected from the analog video or the 

15 digital video by a multiplexer. Bypass video, which may come into 
the chip on a separate input, includes analog video that is 
digitized off-chip into conventional YUV (luma chroma) format by 
any suitable decoder, such as the BT829 decoder, available from 
Brooktree Corporation, San Diego, California. The YUV format may 

20 also be referred to as YCrCb format where Cr and Cb are equivalent 
to U and V, respectively. 

The video decoder (VDEC) 50 preferably digitizes and processes 
analog input video to produce internal YUV component signals with 

25 separated luma and chroma components. In an alternate embodiment, 
the digitized signals may be processed in another format, such as 
RGB. The VDEC 50 preferably includes a sample rate converter 70 
and a time base corrector 72 that together allow the system to 
receive non-standard video signals, such as signals from a VCR. 

30 The time base corrector 72 enables the video encoder to work in 
passthrough mode, and corrects digitized analog video in the time 
domain to reduce or prevent jitter. 

The video scaler 52 may perform both downscaling and upscaling 
35 of digital video and analog- video as needed. In the preferred 
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embodiment, scale factors may be adjusted continuously from a scale 
factor of much less than one to a scale factor of four. With both 
analog and digital video input, either one may be scaled while the 
other is displayed full size at the same time as passthrough video. 
5 Any portion of the input may be the source for video scaling. To 
conserve memory and bandwidth, the video scaler preferably 
downscales before capturing video frames to memory, and upscales 
after reading from memory, but preferably does not perform both 
upscaling and downscaling at the same time. 

10 

The memory controller 54 preferably reads and writes video and 
graphics data to and from memory by usi^g burst accesses with burst 
lengths that may be assigned to each task. The memory is any 
suitable memory such as SDRAM. In the preferred embodiment, the 
15 memory controller includes two substantially similar SDRAM 
controllers, one primarily for the CPU and the other primarily for 
the graphics display system, while either controller may be used 
for any and all of these functions. 

20 The graphics display system preferably processes graphics data 

using logical windows, also referred to as viewports, surfaces, 
sprites, or canvasses, that may overlap or cover one another with 
arbitrary spatial relationships. Each window is preferably 
independent of the others. The windows may consist of any 

25 combination of image content, including anti-aliased text and 
graphics, patterns, GIF images, JPEG images, live video from MPEG 
or analog video, three dimensional graphics, cursors or pointers, 
control panels, menus, tickers, or any other content, all or some 
of which may be animated. 

30 

Graphics windows are preferably characterized by window 
descriptors. Window descriptors are data structures that describe 
one or more parameters of the graphics window. Window descriptors 
may include, for example, image pixel format, pixel color type, 
35 alpha blend factor, location on the screen, address in memory, 
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depth order on the screen, or other parameters. The system 
preferably supports a wide variety of pixel formats, including RGB 
16, RGB 15, YUV 4:2:2 (ITU-R 601), CLUT2, CLUT4, CLUT8 or others. 
In addition to each window having its own alpha blend factor, each 
5 pixel in the preferred embodiment has its own alpha value. In the 
preferred embodiment, window descriptors are not used for video 
windows. Instead, parameters for video windows, such as memory 
start address and window size are stored in registers associated 
with the video compositor. 

10 

In operation, the window controller 56 preferably manages both 
the video and graphics display pipelines. The window controller 
preferably accesses graphics window descriptors in memory through 
a direct memory access (DMA) engine 76. The window controller may 

15 sort the window descriptors according to the relative depth of 
their corresponding windows on the display. For graphics windows, 
the window controller preferably sends header information to the 
display engine at the beginning of each window on each scan line, 
and sends window header packets to the display engine as needed to 

20 display a window. For video, the window controller preferably 
coordinates capture of non-passthrough video into memory, and 
transfer of video between memory and the video compositor. 

The display engine 58 preferably takes graphics information 
25 from memory and processes it for display. The display engine 
preferably converts the various formats of graphics data in the 
graphics windows into YUV component format, and blends the graphics 
windows to create blended graphics output having a composite alpha 
value that is based on alpha values for individual graphics 
30 windows, alpha values per pixel, or both. In the preferred 
embodiment, the display engine transfers the processed graphics 
information to memory buffers that are configured as line buffers. 
In an alternate embodiment, the buffer may include a frame buffer. 
In another alternate embodiment, the output of the display engine 
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is transferred directly to a display or output block without being 
transferred to memory buffers. 

The video compositor 60 receives one or more types of data, 
5 such as blended graphics data, video window data, passthrough video 
data and background color data, and produces a blended video 
output. The video encoder 62 encodes the blended video output from 
the video compositor into any suitable display format such as 
composite NTSC, PAL, Y/C (S-video) , SECAM or other signals that may 
10 include video information, graphics information, or a combination 
of video and graphics information. In an alternate embodiment, the 
video encoder converts the blended video output of the video 
compositor into serial digital video output using an on-chip or off 
chip serializer that may encrypt the output. 

15 

The graphics accelerator 64 preferably performs graphics 
operations that may require intensive CPU processing, such as 
operations on three dimensional graphics images. The graphics 
accelerator may be programmable. The audio engine 66 preferably 

20 supports applications that create and play audio locally within a 
set-top box and allow mixing of the locally created audio with 
audio from a digital audio source, such as MPEG or Dolby, and with 
digitized analog audio. The audio engine also preferably supports 
applications that capture digitized baseband audio via an audio 

25 capture port and store sounds in memory for later use, or that 
store audio to memory for temporary buffering in order to delay the 
audio for precise lip-syncing when frame-based video time 
correction is enabled. 

30 Referring to FIG. 3, in an alternate embodiment of the present 

invention, the graphics display system further includes an I/O bus 
74 connected between the CPU 22, memory 28 and one or more of a 
wide variety of peripheral devices, such as flash memory, ROM, MPEG 
decoders, cable modems or other devices. The on-chip I/O bus 74 of 
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the present invention preferably eliminates the need for a separate 
interface connection, sometimes referred in the art to as a north 
bridge. The I/O bus preferably provides high speed access and data 
transfers between the CPU, the memory and the peripheral devices, 
5 and may be used to support the full complement of devices that may 
be used in a full featured set-top box or digital TV. In the 
preferred embodiment, the I/O bus is compatible with the 68000 bus 
definition, including both active DSACK and passive DSACK (e.g., 
ROM/flash devices), and it supports external bus masters and retry 
10 operations as both master and slave. The bus preferably supports 
any mix of 32-bit, 16-bit and 8-bit devices, and operates at a 
clock rate of 33 MHz. The clock rate is preferably asynchronous 
with (not synchronized with) the CPU clock to enable independent 
optimization of those subsystems. 

15 

Referring to FIG. 4, the graphics display system generally 
includes a graphics display pipeline 80 and a video display 
pipeline 82. The graphics display pipeline preferably contains 
functional blocks, including window control block 84, DMA (direct 

20 memory access) block 86, FIFO (first-in-first-out memory) block 88, 
graphics converter block 90, color look up table (CLUT) block 92, 
graphics blending block 94, static random access memory (SRAM) 
block 96, and filtering block 98. The system preferably spatially 
processes the graphics data independently of the video data prior 

25 to blending. 

In operation, the window control block 84 obtains and stores 
graphics window descriptors from memory and uses the window 
descriptors to control the operation of the other blocks in the 
30 graphics display pipeline. The windows may be processed in any 
order. In the preferred embodiment, on each scan line, the system 
processes windows one at a time from back to front and from the 
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left edge to the right edge of the window before proceeding to the 
next window. In an alternate embodiment, two or more graphics 
windows may be processed in parallel. In the parallel 

implementation, it is possible for all of the windows to be 
5 processed at once, with the entire scan line being processed left 
to right. Any number of other combinations may also be 

implemented, such as processing a set of windows at a lower level 
in parallel, left to right, followed by the processing of another 
set of windows in parallel at a higher level. 

10 

The DMA block 86 retrieves data from memory 110 as needed to 
construct the various graphics windows according to addressing 
information provided by the window control block. Once the display 
of a window begins, the DMA block preferably retains any parameters 

15 that may be needed to continue to read required data from memory. 
Such parameters may include, for example, the current read address, 
the address of the start of the next lines, the number of bytes to 
read per line, and the pitch. Since the pipeline preferably 
includes a vertical filter block for anti-flutter and scaling 

20 purposes, the DMA block preferably accesses a set of adjacent 
display lines in the same frame, in both fields. If the output of 
the system is NTSC or other form of interlaced video, the DMA 
preferably accesses both fields of the interlaced final display 
under certain conditions, such as when the vertical filter and 
-25 scaling are enabled. In such a case, all lines, not just those 
from the current display field, are preferably read from memory and 
processed during every display field. In this embodiment, the 
effective rate of reading and processing graphics is equivalent to 
that of a non-interlaced display with a frame rate equal to the 

30 field rate of the interlaced display. 
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The FIFO block 8 8 temporarily stores data read from the memory 
110 by the DMA block 86, and provides the data on demand to the 
graphics converter block 90. The FIFO may also serve to bridge a 
boundary between different clock domains in the event that the 
5 memory and DMA operate under a clock frequency or phase that 
differs from the graphics converter block 90 and the graphics 
blending block 94. In an alternate embodiment, the FIFO block is 
not needed. The FIFO block may be unnecessary, for example, if the 
graphics converter block processes data from memory at the rate 
10 that it is read from the memory and the memory and conversion 
functions are in the same clock domain. 

In the preferred embodiment, the graphics converter block 90 
takes raw graphics data from the FIFO block and converts it to 

15 YUValpha (YUVa) format. Raw graphics data may include graphics 
data from memory that has not yet been processed by the display 
engine. One type of YUVa format that the system may use includes 
YUV 4:2:2 (i.e. two U and V samples for every four Y samples) plus 
an 8-bit alpha value for every pixel, which occupies overall 24 

20 bits per pixel. Another suitable type of YUVa format includes YUV 
4:4:4 plus the 8-bit alpha value per pixel, which occupies 32 bits 
per pixel. In an alternate embodiment, the graphics converter may 
convert the raw graphics data into a different format, such as 
RGBalpha . 

25 

The alpha value included in the YUVa output may depend on a 
number of factors, including alpha from chroma keying in which a 
transparent pixel has an alpha equal to zero, alpha per CLUT entry, 
alpha from Y (luma) , or alpha per window where one alpha value 
30 characterizes all of the contents of a given window. 
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The graphics converter block 90 preferably accesses the CLUT 
92 during conversion of CLUT formatted raw graphics data. In one 
embodiment of the present invention, there is only one CLUT. In an 
alternate embodiment, multiple CLUTs are used to process different 
graphics windows having graphics data with different CLUT formats. 
The CLUT may be rewritten by retrieving new CLUT data via the DMA 
block when required. In practice, it typically takes longer to 
rewrite the CLUT than the time available in a horizontal blanking 
interval, so the system preferably allows one horizontal line 
period to change the CLUT. Non-CLUT images may be displayed while 
the CLUT is being changed. The color space of the entries in the 
CLUT is preferably in YUV but may also be implemented in RGB. 

The graphics blending block 94 receives output from the 
graphics converter block 90 and preferably blends one window at a 
time along the entire width of one scan line, with the back-most 
graphics window being processed first. The blending block uses the 
output from the converter block to modify the contents of the SRAM 
96. The result of each pixel blend operation is a pixel in the 
SRAM that consists of the weighted sum of the various graphics 
layers up to and including the present one, and the appropriate 
alpha blend value for the video layers, taking into account the 
graphics layers up to and including the present one. 

The SRAM 96 is preferably configured as a set of graphics line 
buffers, where each line buffer corresponds to a single display 
line. The blending of graphics windows is preferably performed one 
graphics window at a time on the display line that is currently 
being composited into a line buffer. Once the display line in a 
line buffer has been completely composited so that all the graphics 
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windows on that display line have been blended, the line buffer is 
made available to the filtering block 98. 

The filtering block 98 preferably performs both anti-flutter 
5 filtering (AFF) and vertical sample rate conversion (SRC) using the 
same filter. This block takes input from the line buffers and 
performs finite impulse response polyphase filtering on the data. 
While anti-flutter filtering and vertical axis SRC are done in the 
vertical axis, there may be different functions, such as horizontal 

10 SRC or scaling that are performed in the horizontal axis. In the 
preferred embodiment, the filter takes input from only vertically 
adjacent pixels at one time. It multiplies each input pixel times 
a specified coefficient, and sums the result to produce the output. 
The polyphase action means that the coefficients, which are samples 

15 of an approximately continuous impulse response, may be selected 
from a different fractional-pixel phase of the impulse response 
every pixel. In an alternate embodiment, where the filter performs 
horizontal scaling, appropriate coefficients are selected for a 
finite impulse response polyphase filter to perform the horizontal 

20 scaling. In an alternate embodiment, both horizontal and vertical 
filtering and scaling can be performed. 

The video display pipeline 82 may include a FIFO block 100, an 
SRAM block 102, and a video scaler 104. The video display pipeline 

25 portion of the architecture is similar to that of the graphics 
display pipeline, and it shares some elements with it. In the 
preferred embodiment, the video pipeline supports up to one scaled 
video window per scan line, one passthrough video window, and one 
background color, all of which are logically behind the set of 

30 graphics windows. The order of these windows, from back to front, 
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is preferably fixed as background color, then passthrough video, 
then scaled video. 

The video windows are preferably in YUV format, although they 
5 may be in either 4:2:2 or 4:2:0 variants or other variants of YUV, 
or alternatively in other formats such as RGB. The scaled video 
window may be scaled up in both directions by the display engine, 
with a factor that can range up to four in the preferred 
embodiment. Unlike graphics, the system generally does not have to 
10 correct for square pixel aspect ratio with video. The scaled video 
window may be alpha blended into passthiough video and a background 
color, preferably using a constant alpha value for each video 
signal . 

15 The FIFO block 100 temporarily stores captured video windows 

for transfer to the video scaler 104. The video scaler preferably 
includes a filter that performs both upscaling and downscaling. The 
scaler function may be a set of two polyphase SRC functions, one 
for each dimension. The vertical SRC may be a four-tap filter with 

20 programmable coefficients in a fashion similar to the vertical 
filter in the graphics pipeline, and the horizontal filter may use 
an 8-tap SRC, also with programmable coefficients. In an alternate 
embodiment, a shorter horizontal filter is used, such as a 4-tap 
horizontal SRC for the video upscaler. Since the same filter is 

25 preferably used for downscaling, it may be desirable to use more 
taps than are strictly needed for upscaling to accommodate low pass 
filtering for higher quality downscaling. 

In the preferred embodiment, the video pipeline uses a 
30 separate window controller and DMA. In an alternate embodiment, 
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these elements may be shared. The FIFOs are logically separate but 
may be implemented in a common SRAM. 

The video compositor block 108 blends the output of the 
5 graphics display pipeline, the video display pipeline, and 
passthrough video. The background color is preferably blended as 
the lowest layer on the display, followed by passthrough video, the 
video window and blended graphics. In the preferred embodiment, 
the video compositor composites windows directly to the screen 
10 line-by-line at the time the screen is displayed, thereby 
conserving memory and bandwidth. The video compositor may include, 
but preferably does not include, display frame buffers, double- 
buffered displays, off-screen bit maps, or blitters. 

15 Referring to FIG. 5, the display engine 58 preferably includes 

graphics FIFO 132, graphics converter 134, RGB-to-YUV converter 
136, YUV-444-to-YUV422 converter 138 and graphics blender 140. The 
graphics FIFO 132 receives raw graphics data from memory through a 
graphics DMA 124 and passes it to the graphics converter 134, which 

20 preferably converts the raw graphics data into YUV 4:4:4 format or 
other suitable format. A window controller 122 controls the 
transfer of raw graphics data from memory to the graphics converter 
132. The graphics converter preferably accesses the RGB-to-YUV 
converter 136 during conversion of RGB formatted data and the 

25 graphics CLUT 146 during conversion of CLUT formatted data. The 
RGB-to-YUV converter is preferably a color space converter that 
converts raw graphics data in RGB space to graphics data in YUV 
space. The graphics CLUT 14 6 preferably includes a CLUT 150, which 
stores pixel values for CLUT-f ormatted graphics data, and a CLUT 

30 controller 152, which controls operation of the CLUT. 
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The YUV44 4-to-YUV422 converter 138 converts graphics data from 
YUV 4:4:4 format to YUV 4:2:2 format. The term YUV 4:4:4 means, as 
is conventional, that for every four horizontally adjacent samples, 
there are four Y values, four U values, and four V values; the term 
5 YUV 4:2:2 means, as is conventional, that for every four samples, 
there are four Y values, two U values and two V values. The 
YUV444-to-YUV422 converter 138 is preferably a UV decimator that 
sub-samples U and V from four samples per every four samples of Y 
to two samples per every four samples of Y. 

10 

Graphics data in YUV 4:4:4 format and YUV 4:2:2 format 
preferably also includes four alpha values for every four samples. 
Graphics data in YUV 4:4:4 format with four alpha values for every 
four samples may be referred to as being in aYUV 4:4:4:4 format; 
15 graphics data in YUV 4:2:2 format with four alpha values for every 
four samples may be referred to as being in aYUV 4:4:2:2 format. 

The YUV444-to-YUV422 converter may also perform low-pass 
filtering of UV and alpha. For example, if the graphics data with 
20 YUV 4:4:4 format has higher than desired frequency content, a low 
pass filter in the YUV 4 4 4 -to-YUV422 converter may be turned on to 
filter out high frequency components in the U and V signals, and to 
perform matched filtering of the alpha values. 

25 The graphics blender 140 blends the YUV 4:2:2 signals 

together, preferably one line at a time using alpha blending, to 
create a single line of graphics from all of the graphics windows 
on the current display line. The filter 170 preferably includes a 
single 4-tap vertical polyphase graphics filter 172, and a vertical 

30 coefficient memory 174. The graphics filter may perform both anti- 
flutter filtering and vertical scaling. The filter preferably 
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receives graphics data from the display engine through a set of 
seven line buffers 59, where four of the seven line buffers 
preferably provide data to the taps of the graphics filter at any 
given time. 

5 

In the preferred embodiment, the system may receive video 
input that includes one decoded MPEG video in ITU-R 65 6 format and 
one analog video signal. The ITU-R 656 decoder 160 processes the 
decoded MPEG video to extract timing and data information. In one 
10 embodiment, an on-chip video decoder (VDEC) 50 converts the analog 
video signal to a digitized video signal. In an alternate 
embodiment, an external VDEC such as the Brooktree BT829 decoder 
converts the analog video into digitized analog video and provides 
the digitized video to the system as bypass video 130. 

15 

Analog video or MPEG video may be provided to the video 
compositor as passthrough video. Alternatively, either type of 
video may be captured into memory and provided to the video 
compositor as a scaled video window. The digitized analog video 
20 signals preferably have a pixel sample rate of 13.5 MHz, contain a 
16 bit data stream in YUV 4:2:2 format, and include timing signals 
such as top field and vertical sync signals. 

The VDEC 50 includes a time base corrector (TBC) 72 comprising 
25 a TBC controller 164 and a FIFO 166. To provide passthrough video 
that is synchronized to a display clock preferably without using a 
frame buffer, the digitized analog video is corrected in the time 
domain in the TBC 72 before being blended with other graphics and 
video sources. During time base correction, the video input which 
30 runs nominally at 13.5 MHZ is synchronized with the display clock 
which runs nominally at 13.5 MHZ at the output; these two 
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frequencies that are both nominally 13.5 MHz are not necessarily 
exactly the same frequency. In the TBC, the video output is 
preferably offset from the video input by a half scan line per 
field. 

5 

A capture FIFO 158 and a capture DMA 154 preferably capture 
the digitized analog video signals and MPEG video. The SDRAM 
controller 126 provides captured video frames to the external 
SDRAM. A video DMA 144 transfers the captured video frames to a 
10 video FIFO 148 from the external SDRAM. 

The digitized analog video signals and MPEG video are 
preferably scaled down to less than 100% prior to being captured 
and are scaled up to more than 100% after being captured. The 

15 video scaler 52 is shared by both upscale and downscale operations. 
The video scaler preferably includes a multiplexer 176, a set of 
line buffers 178, a horizontal and vertical coefficient memory 180 
and a scaler engine 182. The scaler engine 182 preferably includes 
a set of two polyphase filters, one for each of horizontal and 

20 vertical dimensions. 

The vertical filter preferably includes a four-tap filter with 
programmable filter coefficients. The horizontal filter preferably 
includes an eight-tap filter with programmable filter coefficients. 

.25 In the preferred embodiment, three line buffers 178 supply video 
signals to the scaler engine 182. The three line buffers 178 
preferably are 720 x 16 two port SRAM. For vertical filtering, the 
three line buffers 178 may provide video signals to three of the 
four taps of the four-tap vertical filter while the video input 

30 provides the video signal directly to the fourth tap. For 
horizontal filtering, a shift register having eight cells in series 
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may be used to provide inputs to the eight taps of the horizontal 
polyphase filter, each cell providing an input to one of the eight 
taps . 

5 For downscaling, the multiplexer 168 preferably provides a 

video signal to the video scaler prior to capture. For upscaling, 
the video FIFO 148 provides a video signal to the video scaler 
after capture. Since the video scaler 52 is shared between 
downscaling and upscaling filtering, downscaling and upscaling 
10 operations are not performed at the same time in this particular 
embodiment . 

In the preferred embodiment, the video compositor 60 blends 
signals from up to four different sources, which may include 

15 blended graphics from the filter 170, video from a video FIFO 148, 
passthrough video from a multiplexer 168, and background color from 
a background color module 184. Alternatively, various numbers of 
signals may be composited, including, for example, two or more 
video windows. The video compositor preferably provides final 

20 output signal to the data size converter 190, which serializes the 
16-bit word sample into an 8-bit word sample at twice the clock 
frequency, and provides the 8-bit word sample to the video encoder 
62. 

25 The video encoder 62 encodes the provided YUV 4:2:2 video data 

and outputs it as an output of the graphics display system in any 
desired analog or digital format. 
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II. Window Descriptor and Solid Surface Description 

Often in the creation of graphics displays, the artist or 
application developer has a need to include rectangular objects on 
5 the screen, with the objects having a solid color and a uniform 
alpha blend factor (alpha value). These regions (or objects) may 
be rendered with other displayed objects on top of them or beneath 
them. In conventional graphics devices, such solid color objects 
are rendered using the number of distinct pixels required to fill 
10 the region. It may be advantageous in terms of memory size and 
memory bandwidth to render such objects on the display directly, 
without expending the memory size or bandwidth required in 
conventional approaches . 

15 In the preferred embodiment, video and graphics are displayed 

on regions referred to as windows. Each window is preferably a 
rectangular area of screen bounded by starting and ending display 
lines and starting and ending pixels on each display line. Raw 
graphics data to be processed and displayed on a screen preferably 

20 resides in the external memory. In the preferred embodiment, a 
display engine converts raw graphics data into a pixel map with a 
format that is suitable for display. 

In one embodiment of the present invention, the display engine 
25 implements graphics windows of many types directly in hardware. 

Each of the graphics windows on the screen has its own value of 
various parameters, such as location on the screen, starting 
address in memory, depth order on the screen, pixel color type, 
etc. The graphics windows may be displayed such that they may 
30 overlap or cover each other, with arbitrary spatial relationships. 
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In the preferred embodiment, a data structure called a window 
descriptor contains parameters that describe and control each 
graphics window. The window descriptors are preferably data 
structures for representing graphics images arranged in logical 
5 surfaces, or windows, for display. Each data structure preferably 
includes a field indicating the relative depth of the logical 
surface on the display, a field indicating the alpha value for the 
graphics in the surface, a field indicating the location of the 
logical surface on the display, and a field indicating the location 
10 in memory where graphics image data for the logical surface is 
stored . 

All of the elements that make up any given graphics display 
screen are preferably specified by combining all of the window 

15 descriptors of the graphics windows that make up the screen into a 
window descriptor list. At every display field time or a frame 
time, the display engine constructs the display image from the 
current window descriptor list. The display engine composites all 
of the graphics windows in the current window descriptor list into 

20 a complete screen image in accordance with the parameters in the 
window descriptors and the raw graphics data associated with the 
graphics windows. 

With the introduction of window descriptors and real-time 
25 composition of graphics windows, a graphics window with a solid 
color and fixed translucency may be described entirely in a window 
descriptor having appropriate parameters. These parameters 
describe the color and the translucency (alpha) just as if it were 
a normal graphics window. The only difference is that there is no 
30 pixel map associated with this window descriptor. The display 
engine generates a pixel map accordingly and performs the blending 
in real time when the graphics window is to be displayed. 
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For example, a window consisting of a rectangular object 
having a constant color and a constant alpha value may be created 
on a screen by including a window descriptor in the window 
descriptor list. In this case, the window descriptor indicates the 
color and the alpha value of the window, and a null pixel format, 
i.e., no pixel values are to be read from memory. Other parameters 
indicate the window size and location on the screen, allowing the 
creation of solid color windows with any size and location. Thus, 
in the pref err ad embodiment, no pixel map is required, memory 
bandwidth requirements are reduced and a window of any size may be 
displayed . 

Another type of graphics window that the window descriptors 
preferably describe is an alpha-only type window. The alpha-only 
type windows preferably use a constant color and preferably have 
graphics data with 2, 4 or 8 bits per pixel. For example, an 
alpha-4 format may be an alpha-only format used in one of the 
alpha-only type windows. The alpha-4 format specifies the alpha- 
only type window with alpha blend values having four bits per 
pixel. The alpha-only type window may be particularly useful for 
displaying anti-aliased text. 

A window controller preferably controls transfer of graphics 
display information in the window descriptors to the display 
engine. In one embodiment, the window controller has internal 
memory to store eight window descriptors. In other embodiments, 
the window controller may have memory allocated to store more or 
less window descriptors. The window controller preferably reads 
the window descriptors from external memory via a direct memory 
access (DMA) module. 

The DMA module may be shared by both paths of the display 
pipeline as well as some of the control logic, such as the window 
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controller and the CLUT . In order to support the display pipeline, 
the DMA module preferably has three channels where the graphics 
pipeline and the video pipeline use separate DMA modules. These 
may include window descriptor read, graphics data read and CLUT 
read. Each channel has externally accessible registers to control 
the start address and the number of words to read. 

Once the DMA module has completed a transfer as indicated by 
its start and length registers, it preferably activates a signal 
that indicates the transfer is complete. This allows the DMA 
module that sets up operations for that channel to begin setting up 
of another transfer. In the case of graphics data reads, the 
window controller preferably sets up a transfer of one line of 
graphics pixels and then waits for the DMA controller to indicate 
that the transfer of that line is complete before setting up the 
transfer of the next line, or of a line of another window. 

Referring to FIG. 6, each window descriptor preferably 
includes four 32-bit words (labeled Word 0 through Word 3) 
containing graphics window display information. Word 0 preferably 
includes a window operation parameter, a window format parameter 
and a window memory start address. The window operation parameter 
preferably is a 2-bit field that indicates which operation is to be 
performed with the window descriptor. When the window operation 
parameter is 00b, the window descriptor performs a normal display 
operation and when it is 01b, the window descriptor performs 
graphics color look-up table ("CLUT") re-loading. The window 
operation parameter of 10b is preferably not used. The window 
operation parameter of lib preferably indicates that the window 
descriptor is the last of a sequence of window descriptors in 
memory . 
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The window format parameter preferably is a 4-bit field that 
indicates a data format of the graphics data to be displayed in the 
graphics window. The data formats corresponding to the window 
5 format parameter is described in Table 1 below. 



win 
format 


Data 
Format 


Data Format Description 


0000b 


RGB16 


5-BIT RED, 6-BIT GREEN, 5-BIT BLUE 


0001b 


RGB15+1 


RGB15 plus one bit alpha (keying) 


0010b 


RGBA4 4 44 


4-BIT RED, GREEN, BLUE, ALPHA 


0100b 


CLUT2 


2-bit CLUT with YUV and alpha in table 


0101b 


CLUT4 


4-bit CLUT with YUV and alpha in table 


0110b 


CLUT8 


8-bit CLUT with YUV and alpha in table 


0111b 


ACLUT16 


8-BIT ALPHA, 8-BIT CLUT INDEX 


1000b 


ALPHA0 


Single win_alpha and single RGB win color 


1001b 


ALPHA2 


2-bit alpha with single RGB win color 


1010b 


ALPHA4 


4-bit alpha with single RGB win color 


1011b 


ALPHA8 


8-bit alpha with single RGB win color 


1100b 


YUV422 


U and V are sampled at half the rate of Y 


1111b 


RESERVED 


Special coding for blank line in new header, 
i.e., indicates an empty line 



TABLE 1 : Graphics Data Formats 



The window memory start address preferably is a 26-bit data 
10 field that indicates a starting memory address of the graphics data 
of the graphics window to be displayed on the screen. The window 
memory start address points to the first address in the 
corresponding external SDRAM which is accessed to display data on 
the graphics window defined by the window descriptor. When the 
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window operation parameter indicates the graphics CLUT reloading 
operation, the window memory start address indicates a starting 
memory address of data to be loaded into the graphics CLUT. 

5 Word 1 in the window descriptor preferably includes a window 

layer parameter, a window memory pitch value and a window color 
value. The window layer parameter is preferably a 4-bit data 
indicating the order of layers of graphics windows. Some of the 
graphics windows may be partially or completely stacked on top of 
10 each other, and the window layer parameter indicates the stacking 
order. The window layer parameter preferably indicates where in 
the stack the graphics window defined by the window descriptor 
should be placed. 

15 In the preferred embodiment, a graphics window with a window 

layer parameter of 0000b is defined as the bottom most layer, and 
a graphics window with a window layer parameter of 1111b is defined 
as the top most layer. Preferably, up to eight graphics windows 
may be processed in each scan line. The window memory pitch value 

20 is preferably a 12-bit data field indicating the pitch of window 
memory addressing. Pitch refers to the difference in memory address 
between two pixels that are vertically adjacent within a window. 

The window color value preferably is a 16-bit RGB color, which 
25 is applied as a single color to the entire graphics window when the 
window format parameter is 1000b, 1001b, 1010b, or 1011b. Every 
pixel in the window preferably has the color specified by the 
window color value, while the alpha value is determined per pixel 
and per window as specified in the window descriptor and the pixel 
30 format. The engine preferably uses the window color value to 
implement a solid surface. 
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Word 2 in the window descriptor preferably includes an alpha 
type, a widow alpha value, a window y-end value and a window y- 
start value. The word 2 preferably also includes two bits reserved 
5 for future definition, such as high definition television (HD) 
applications. The alpha type is preferably a 2-bit data field that 
indicates the method of selecting an alpha value for the graphics 
window. The alpha type of 00b indicates that the alpha value is to 
be selected from chroma keying. Chroma keying determines whether 

10 each pixel is opaque or transparent based on the color of the 
pixel. Opaque pixels are preferably considered to have an alpha 
value of 1.0, and transparent pixels have an alpha value of 0, both 
on a scale of 0 to 1 . Chroma keying compares the color of each 
pixel to a reference color or to a range of possible colors; if the 

15 pixel matches the reference color, or if its color falls within the 
specified range of colors, then the pixel is determined to be 
transparent. Otherwise it is determined to be opaque. 

The alpha type of 01b indicates that the alpha value should be 
20 derived from the graphics CLUT, using the alpha value in each entry 
of the CLUT. The alpha type of 10b indicates that the alpha value 
is to be derived from the luminance Y. The Y value that results 
from conversion of the pixel color to the YUV color space, if the 
pixel color is not already in the YUV color, is used as the alpha 
25 value for the pixel. The alpha type of lib indicates that only a 
single alpha value is to be applied to the entire graphics window. 
The single alpha value is preferably included as the window alpha 
value next. 

30 The window alpha value preferably is an 8-bit alpha value 

applied to the entire graphics window. The effective alpha value 
for each pixel in the window is the product of the window alpha and 
the alpha value determined for each pixel. For example, if the 
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window alpha value is 0 . 5 on a scale of 0 to 1, coded as 0x80, then 
the effective alpha value of every pixel in the window is one-half 
of the value encoded in or for the pixel itself. If the window 
format parameter is 1000b, i.e., a single alpha value is to be 
5 applied to the graphics window, then the per-pixel alpha value is 
treated as if it is 1.0, and the effective alpha value is equal to 
the window alpha value. 

The window y-end value preferably is a 10-bit data field that 
indicates the ending display line of the graphics window on the 
screen. The graphics window defined by the window descriptor ends 
at the display line indicated by the window y-end value. The 
window y-start value preferably is a 10-bit data field that 
indicates a starting display line of the graphics window on a 
screen. The graphics window defined by the window descriptor begins 
at the display line indicated in the window y-start value. Thus, 
a display of a graphics window can start on any display line on the 
screen based on the window y-start value. 

20 Word 3 in the window descriptor preferably includes a window 

filter enable parameter, a blank start pixel value, a window x-size 
value and a window x-start value. In addition, the word 3 includes 
two bits reserved for future definition, such as HD applications. 
Five bits of the 32-bit word 3 are not used. The window filter 

25 enable parameter is a 1-bit field that indicates whether low pass 
filtering is to be enabled during YUV 4:4:4 to YUV 4:2:2 
conversion . 

The blank start pixel value preferably is a 4-bit parameter 
30 indicating a number of blank pixels at the beginning of each 
display line. The blank start pixel value preferably signifies the 
number of pixels of the first word read from memory, at the 
beginning of the corresponding graphics window, to be discarded. 
This field indicates the number of pixels in the first word of data 
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read from memory that are not displayed. For example, if memory 
words are 32 bits wide and the pixels are 4 bits each, there are 8 
possible first pixels in the first word. Using this field, 0 to 7 
pixels may be skipped, making the 1 st to the 8 th pixel in the word 
5 appear as the first pixel, respectively. The blank start pixel 
value allows graphics windows to have any horizontal starting 
position on the screen, and may be used during soft horizontal 
scrolling of a graphics window. 

10 The window x-size value preferably is a 10-bit data field that 

indicates the size of a graphics window in the x direction, i.e., 
horizontal direction. The window x-size value preferably indicates 
the number of pixels of a graphics window in a display line. 

15 The window x-start value preferably is a 10-bit data field 

that indicates a starting pixel of the graphics window on a display 
line. The graphics window defined by the window descriptor 
preferably begins at the pixel indicated by the window x-start 
value of each display line. With the window x-start value, any 

20 pixel of a given display line can be chosen to start painting the 
graphics window. Therefore, there is no need to load pixels on the 
screen prior to the beginning of the graphics window display area 
with black. 

25 III. Graphics Window Control Data Passing Mechanism 

In one embodiment of the present invention, a FIFO in the 
graphics display path accepts raw graphics data as the raw graphics 
data is read from memory, at the full memory data rate using a 
30 clock of the memory controller. In this embodiment, the FIFO 
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provides this data, initially stored in an external memory, to 
subsequent blocks in the graphics pipeline. 

In systems such as graphics display systems where multiple 
types of data may be output from one module, such as a memory 
controller subsystem, and used in another subsystem, such as a 
graphics processing subsystem, it typically becomes progressively 
more difficult to support a combination of dynamically varying data 
types and data transfer rates and FIFO buffers between the 
producing and consuming modules. The conventional way to address 
such problems is to design a logic block that understands the 
varying parameters of the data types in the first module and 
controls all of the relevant variables in the second module. This 
may be difficult due to variable delays between the two modules, 
due to the use of FIFOs between them and varying data rate, and due 
to the complexity of supporting a large number of data types. 

The system preferably processes graphics images for display by 
organizing the graphics images into windows in which the graphics 
images appear on the screen, obtaining data that describes the 
windows, sorting the data according to the depth of the window on 
the display, transferring graphics images from memory, and blending 
the graphics images using alpha values associated with the graphics 
images . 

In the preferred embodiment, a packet of control information 
called a header packet is passed from the window controller to the 
display engine. All of the required control information from the 
window controller preferably is conveyed to the display engine such 
that all of the relevant variables from the window controller are 
properly controlled in a timely fashion and such that the control 
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is not dependent on variations in delays or data rates between the 
window controller and the display engine. 

A header packet preferably indicates the start of graphics 
5 data for one graphics window. The graphics data for that graphics 
window continues until it is completed without requiring a transfer 
of another header packet. A new header packet is preferably placed 
in the FIFO when another window is to start. The header packets 
may be transferred according to the order of the corresponding 
10 window descriptors in the window descriptor lists. 

In a display engine that operates according to lists of window 
descriptors, windows may be specified to overlap one another. At 
the same time, windows may start and end on any line, and there may 

15 be many windows visible on any one line. There are a large number 
of possible combinations of window starting and ending locations 
along vertical and horizontal axes and depth order locations. The 
system preferably indicates the depth order of all windows in the 
window descriptor listand implements the depth ordering correctly 

20 while accounting for all windows. 

Each window descriptor preferably includes a parameter 
indicating the depth location of the associated window. The range 
that is allowed for this parameter can be defined to be almost any 

25 useful value. In the preferred embodiment there are 16 possible 
depth values, ranging from 0 to 15, with 0 being the back-most 
(deepest, or furthest from the viewer) , and 15 being the top or 
front-most depth. The window descriptors are ordered in the window 
descriptor list in order of the first display scan line where the 

30 window appears. For example if window A spans lines 10 to 20, 
window B spans lines 12 to 18, and window C spans lines 5 to 20, 
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the order of these descriptors in the list would be {C, A, B } . 

In the hardware, which is a preferably a VLSI device, there is 
preferably on-chip memory capable of storing a number of window 
5 descriptors. In the preferred implementation, this memory can 
store up to 8 window descriptors on-chip, however the size of this 
memory may be made larger or smaller without loss of generality. 
Window descriptors are read from main memory into the on-chip 
descriptor memory in order from the start of the list, and stopping 

10 when the on-chip memory is full or when the most recently read 
descriptor describes a window that is not yet visible, i.e., its 
starting line is on a line that has a higher number than the line 
currently being constructed. Once a window has been displayed and 
is no longer visible, it may be cast out of the on-chip memory and 

15 the next descriptor in the list may read from main memory. At any 
given display line, the order of the window descriptors in the on- 
chip memory bears no particular relation to the depth order of the 
windows on the screen. 

20 The hardware that controls the compositing of windows builds 

up the display in layers, starting from the back-most layer. In the 
preferred embodiment, the back most layer is layer C. The hardware 
performs a quick search of the back-most window descriptor that has 
not yet been composited, regardless of its location in the on-chip 

25 descriptor memory. In the preferred embodiment, this search is 
performed as follows: 

All 8 window descriptors are stored on chip in such a way that 
the depth order numbers of all of them are available 
30 simultaneously. While the depth numbers in the window descriptors 
are 4 bit numbers, representing 0 to 15, the on-chip memory has 
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storage for 5 bits for the depth number. Initially the 5 bit for 
each descriptor is set to 0. The depth order values are compared 
in a hierarchy of pair-wise comparisons, and the lower of the two 
depth numbers in each comparison wins the comparison. That is, at 
5 the first stage of the test descriptor pairs {0, 1}, {2, 3}, {4, 
5}, and {6, 7} are compared, where {0 - 7} represent the eight 
descriptors stored in the on-chip memory. This results in four 
depth numbers with associated descriptor numbers. At the next stage 
two pair-wise comparisons compare {(0, 1), (2, 3)} and {(4, 5), (6, 
10 7)}. 

Each of these results in a depth number of the lower depth 
order number and the associated descriptor number. At the third 
stage, one pair-wise comparison finds the smallest depth number of 

15 all, and its associated descriptor number. This number points the 
descriptor in the on-chip memory with the lowest depth number, and 
therefore the greatest depth, and this descriptor is used first to 
render the associated window on the screen. Once this window has 
been rendered onto the screen for the current scan line, the fifth 

20 bit of the depth number in the on-chip memory is set to 1, thereby 
ensuring that the depth value number is greater than 15, and as a 
result this depth number will preferably never again be found to be 
the back-most window until all windows have been rendered on this 
scan line, preventing rendering this window twice. 

25 

Once all the windows have been rendered for a given scan line, 
the fifth bits of all the on-chip depth numbers are again set to 0; 
descriptors that describe windows that are no longer visible on the 
screen are cast out of the on-chip memory; new descriptors are read 
30 from memory as required (that is, if all windows in the on-chip 
memory are visible, the next descriptor is read from memory, and 
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this repeats until the most recently read descriptor is not yet 
visible on the screen) , and the process of finding the back most 
descriptor and rendering windows onto the screen repeats. 

5 Referring to FIG. 7, window descriptors are preferably sorted 

by the window controller and used to transfer graphics data to the 
display engine. Each of window descriptors, including the window 
descriptor 0 through the window descriptor 7 300a-h, preferably 
contains a window layer parameter. In addition, each window 
10 descriptor is preferably associated with a window line done flag 
indicating that the window descriptor has been processed on a 
current display line. 

The window controller preferably performs window sorting at 
15 each display line using the window layer parameters and the window 
line done flags. The window controller preferably places the 
graphics window that corresponds to the window descriptor with the 
smallest window layer parameter at the bottom, while placing the 
graphics window that corresponds to the window descriptor with the 
20 largest window layer parameter at the top. 

The window controller preferably transfers the graphics data 
for the bottom-most graphics window to be processed first. The 
window parameters of the bottom-most window are composed into a 

25 header packet and written to the graphics FIFO. The DMA engine 
preferably sends a request to the memory controller to read the 
corresponding graphics data for this window and send the graphics 
data to the graphics FIFO. The graphics FIFO is then read by the 
display engine to compose a display line, which is then written to 

30 graphics line buffers. 

The window line done flag is preferably set true whenever the 
window surface has been processed on the current display line. The 
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window line done flag and the window layer parameter may be 
concatenated together for sorting. The window line done flag is 
added to the window layer parameter as the most significant bit 
during sorting such that {window line done flag[4], window layer 
parameter [3 : 0] } is a five bit binary number, a window layer value, 
with window line done flag as the most significant bit. 

The window controller preferably selects a window descriptor 
with the smallest window layer value to be processed. Since the 
window line done flag is preferably the most significant bit of the 
window layer value, any window descriptor with this flag set, i.e., 
any window that has been processed on the current display line, 
will have a higher window layer value than any of the other window 
descriptors that have not yet been processed on the current display 
line. When a particular window descriptor is processed, the window 
line done flag associated with that particular window descriptor is 
preferably set high, signifying that the particular window 
descriptor has been processed for the current display line. 

A sorter 304 preferably sorts all eight window descriptors 
after any window descriptor is processed. The sorting may be 
implemented using binary tree sorting or any other suitable sorting 
algorithm. In binary tree sorting for eight window descriptors, 
the window layer value for four pairs of window descriptors are 
compared at a first level using four comparators to choose the 
window descriptor that corresponds to a lower window in each pair. 
In the second level, two comparators are used to select the window 
descriptor that corresponds to the bottom most graphics window in 
each of two pairs. In the third and the last level, the bottom- 
most graphics windows from each of the two pairs are compared 
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against each other preferably using only one comparator to select 
the bottom window. 

A multiplexer 302 preferably multiplexes parameters from the 
5 window descriptors. The output of the sorter, i.e., window 
selected to be the bottom most, is used to select the window 
parameters to be sent to a direct memory access ("DMA") module 306 
to be packaged in a header packet and sent to a graphics FIFO 308. 
The display engine preferably reads the header packet in the 
10 graphics FIFO and processes the raw graphics data based on 
information contained in the header packet. 

The header packet preferably includes a first header word and 
a second header word. Corresponding graphics data is preferably 

15 transferred as graphics data words. Each of the first header word, 
the second header word and the graphics data words preferably 
includes 32 bits of information plus a data type bit. The first 
header word preferably includes a 1-bit data type, a 4-bit graphics 
type, a 1-bit first window parameter, a 1-bit top/bottom parameter, 

20 a 2-bit alpha type, an 8-bit window alpha value and a 16-bit window 
color value. Table 2 shows contents of the first header word. 



Bit 

Position 


32 


31-28 


27 


26 


25-24 


23-16 


15-0 


Data 
Content 


Data 
type 


graphics 
type 


First 
Window 


top/ 
bottom 


alpha 
type 


window 
alpha 


window 
color 



TABLE 2 : First Header Word 



25 The 1-bit data type preferably indicates whether a 33-bit word 

in the FIFO is a header word or a graphics data word. A data type 
of 1 indicates that the associated 33-bit word is a header word 
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while the data type of 0 indicates that the associated 33-bit word 
is a graphics data word. The graphics type indicates the data 
format of the graphics data to be displayed in the graphics window 
similar to the window format parameter in the word 0 of the window 
descriptor, which is described in Table 1 above. In the preferred 
embodiment, when the graphics type is 1111, there is no window on 
the current display line, indicating that the current display line 
is empty. 

The first window parameter of the first header word preferably 
indicates whether the window associated with that first header word 
is a first window on a new display line. The top/bottom parameter 
preferably indicates whether the current display line indicated in 
the first header word is at the top or the bottom edges of the 
window. The alpha type preferably indicates a method of selecting 
an alpha value individually for each pixel in the window similar to 
the alpha type in the word 2 of the window descriptor. 

The window alpha value preferably is an alpha value to be 
applied to the window as a whole and is similar to the window alpha 
value in the word 2 of the window descriptor. The window color 
value preferably is the color of the window in 16-bit RGB format 
and is similar to the window color value in the word 1 of the 
window descriptor . 

The second header word preferably includes the 1-bit data 
type, a 4-bit blank pixel count, a 10-bit left edge value, a 1-bit 
filter enable parameter and a 10-bit window size value. Table 3 
shows contents of the second header word in the preferred 
embodiment . 
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Bit 

Position 


32 


31-28 


25-16 


10 


9-0 


Data 
Content 


data 
type 


Blank pixel 
count 


Left edge 


filter 
enabler 


window size 



TABLE 3 : Second Header Word 



5 Similar to the first header word, the second header word 

preferably starts with the data type indicating whether the second 
header word is a header word or a graphics data word. The blank 
pixel count preferably indicates a number of blank pixels at a left 
edge of the window and is similar to the blank start pixel value in 

10 the word 3 of the window descriptor. The left edge preferably 
indicates a starting location of the window on a scan line, and is 
similar to the window x-start value in the word 3 of the window 
descriptor. The filter enable parameter preferably enables a 
filter during a conversion of graphics data from a YUV 4:4:4 format 

15 to a YUV 4:2:2 format and is similar to the window filter enable 
parameter in word 3 of the window descriptor. Some YUV 4:4:4 data 
may contain higher frequency content than others, which may be 
filtered by enabling a low pass filter during a conversion to the 
YUV 4:2:2 format. The window size value preferably indicates the 

20 actual horizontal size of the window and is similar to the window 
x-size value in word 3 of the window descriptor. 

When the composition of the last window of the last display 
line is completed, an empty-line header is preferably placed into 
25 the FIFO so that the display engine may release the display line 
for display. 
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Packetized data structures have been used primarily in "the 
communication world where large amount of data needs to be 
transferred between hardware using a physical data link (e.g., 
wires) . The idea is not known to have been used in the graphics 
5 world where localized and small data control structures need to be 
transferred between different design entities without requiring a 
large off -chip memory as a buffer. In one embodiment of the 
present system, header packets are used, and a general-purpose FIFO 
is used for routing. Routing may be accomplished in a relatively 
10 simple manner in the preferred embodiment because the write port of 
the FIFO is the only interface. 

In the preferred embodiment, the graphics FIFO is a 
synchronous 32 x 33 FIFO built with a static dual-port RAM with one 

15 read port and one write port. The write port preferably is 
synchronous to a 81 MHz memory clock while the read port may be 
asynchronous (not synchronized) to the memory clock. The read port 
is preferably synchronous to a graphics processing clock, which 
runs preferably at 81 MHz, but not necessarily synchronized to the 

20 memory clock. Two graphics FIFO pointers are preferably generated, 
one for the read port and one for the write port. In this 
embodiment, each graphics FIFO pointer is a 6-bit binary counter 
which ranges from 000000b to 111111b, i.e., from 0 to 63. The 
graphics FIFO is only 32 words deep and requires only 5 bits to 

25 represent each 33-bit word in the graphics FIFO. An extra bit is 
preferably used to distinguish between FIFO full and FIFO empty 
states . 

The graphics data words preferably include the 1-bit data type 
30 and 32-bit graphics data bits. The data type is 0 for the graphics 
data words. In order to adhere to a common design practice that 
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generally limits the size of a DMA burst into a FIFO to half the 
size of the FIFO, the number of graphics data words in one DMA 
burst preferably does not exceed 16. 

5 In an alternate embodiment, a graphics display FIFO is not 

used. In this embodiment, the graphics converter processes data 
from memory at the rate that it is read from memory. The memory 
and conversion functions are in a same clock domain. Other 
suitable FIFO designs may be' used. 

10 

Referring to FIG. 8, a flow diagram illustrates a process for 
loading and processing window descriptors. First the system is 
preferably reset in step 310. Then the system in step 312 
preferably checks for a vertical sync ("VSYNC") . When the VSYNC is 
15 received, the system in step 314 preferably proceeds to load window 
descriptors into the window controller from the external SDRAM or 
other suitable memory over the DMA channel for window descriptors. 
The window controller may store up to eight window descriptors in 
one embodiment of the present invention. 

20 

The step in step 316 preferably sends a new line header 
indicating the start of a new display line. The system in step 320 
preferably sorts the window descriptors in accordance with the 
process described in reference to FIG. 7. Although sorting is 

25 indicated as a step in this flow diagram, sorting actually may be 
a continuous process of selecting the bottom-most window, i.e., the 
window to be processed. The system in step 322 preferably checks 
to determine if a starting display line of the window is greater 
than the line count of the current display line. If the starting 

30 display line of the window is greater than the line count, i.e., if 
the current display line is above the starting display line of the 
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bottom most window, the current display line is a blank line. Thus, 
the system in step 318 preferably increments the line count and 
sends another new line header in step 316. The process of sending 
a new line header and sorting window descriptor continues as long 
5 as the starting display line of the bottom most (in layer order) 
window is below the current display line. 

The display engine and the associated graphics filter 
preferably operate in one of two modes, a field mode and a frame 

0 mode. In both modes, raw graphics data associated with graphics 
windows is preferably stored in frame format, including lines from 
both interlaced fields in the case of an interlaced display. In 
the field mode, the display engine preferably skips every other 
display line during processing. In the field mode, therefore, the 

5 system in step 318 preferably increments the line count by two each 
time to skip every other line. In the frame mode, the display 
engine processes every display line sequentially. In the frame 
mode, therefore, the system in step 318 preferably increments the 
line count by one each time. 

0 

When the system in step 322 determines that the starting 
display of the window is greater than the line count, the system in 
step 324 preferably determines from the header packet whether the 
window descriptor is for displaying a window or re-loading the 
5 CLUT. If the window header indicates that the window descriptor is 
for re-loading CLUT, the system in step 328 preferably sends the 
CLUT data to the CLUT and turns on the CLUT write strobe to load 
CLUT. 

0 If the system in step 324 determines that the window 

descriptor is for displaying a window, the system in step 326 
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preferably sends a new window header to indicate that graphics data 
words for a new window on the display line are going to be 
transferred into the graphics FIFO. Then, the system in step 330 
preferably requests the DMA module to send graphics data to the 
5 graphics FIFO over the DMA channel for graphics data. In the event 
the FIFO does not have sufficient space to store graphics data in 
a new data packet, the system preferably waits until such space is 
made available. 

When graphics data for a display line of a current window is 
transferred to the FIFO, the system in step 332 preferably 
determines whether the last line of the current window has been 
transferred. If the last line has been transferred, a window 
descriptor done flag associated with the current window is 
preferably set. The window descriptor done flag indicates that the 
graphics data associated with the current window descriptor has 
been completely transferred. When the window descriptor done flag 
is set, i.e., when the current window descriptor is completely 
processed, the system sets a window descriptor done flag in step 
334. Then the system in step 336 preferably sets a new window 
descriptor update flag and increments a window descriptor update 
counter to indicate that a new window descriptor is to be copied 
from the external memory. 

25 Regardless of whether the last line of the current window has 

been processed, the system in step 338 preferably sets the window 
line done flag for the current window descriptor to signify that 
processing of this window descriptor on the current display line 
has been completed. The system in step 340 preferably checks the 

30 window line done flags associated with all eight window descriptors 
to determine whether they are all set, which would indicate that 

46 
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all the windows of the current display line have been processed." If 
not all window line done flags are set, the system preferably 
proceeds to step 320 to sort the window descriptors and repeat 
processing of the new bottom-most window descriptor. 

5 

If all eight window line done flags are determined to be set 
in step 340, all window descriptors on the current display line 
have been processed. In this case, the system in step 342 
preferably checks whether an all window descriptor done flag has 

10 been set to determine whether all window descriptors have been 
processed completely. The all window descriptor done flag is set 
when processing of all window descriptors in the current frame or 
field have been processed . completely . If the all window descriptor 
done flag is set, the system preferably returns to step 310 to 

15 reset and awaits another VSYNC in step 312. If not all window 
descriptors have been processed, the system in step 344 preferably 
determines if the new window descriptor update flag has been set. 
In the preferred embodiment, this flag would have been set in step 
334 if the current window descriptor has been completely processed. 

20 

When the new window descriptor update flag is set, the system 
in step 352 preferably sets up the DMA to transfer a new window 
descriptor from the external memory. Then the system in step 350 
preferably clears the new window descriptor update flag. After the 

25 system clears the new window descriptor update flag or when the new 
window descriptor update flag is not set in the first place, the 
system in step 348 preferably increments a line counter to indicate 
that the window descriptors for a next display line should be 
processed. The system in step 346 preferably clears all eight 

30 window line done flags to indicate that none of the window 
descriptors have been processed for the next display line. Then 
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the system in step 316 preferably initiates processing of the new 
display line by sending a new line header to the FIFO. 

In the preferred embodiment, the graphics converter in the 
5 display engine converts raw graphics data having various different 
formats into a common format for subsequent compositing with video 
and for display. The graphics converter preferably includes a 
state machine that changes state based on the content of the window 
data packet. Referring to FIG. 9, the state machine in the 

10 graphics converter preferably controls unpacking and processing of 
the header packets. A first header word processing state 354 is 
preferably entered wherein a first window parameter of the first 
header word is checked(step 356) to determine if the window data 
packet is for a first graphics window of a new line. If the header 

15 packet is not for a first window of a new line, after the first 
header word is processed, the state preferably changes to a second 
header word processing state 362. 

If the header packet is for a first graphics window of a new 
20 line, the state machine preferably enters a clock switch state 358. 
In the clock switch state, the clock for a graphics line buffer 
which is going to store the new line switches from a display clock 
to a memory clock, e.g., from a 13.5 MHz clock to a 81 MHz clock. 
From the clock switch state, a graphics type in the first header 
25 word is preferably checked (step 360) to determine if the header 
packet represents an empty line. A graphics type of 1111b 
preferably refers to an empty line. 

If the graphics type is 1111b, the state machine enters the 
30 first header word processing state 354, in which the first header 
word of the next header packet is processed. If the graphics type 
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is not 1111b, i.e. the display line is not empty, the second header 
word is processed. Then the state machine preferably enters a 
graphics content state 364 wherein words from the FIFO are checked 
(step 366) one at a time to verify that they are data words. The 
5 state machine preferably remains in the graphics content state as 
long as each word read is a data word. While in the graphics 
content state, if a word received is not a data word, i.e., it is 
a first or second header word, then the state machine preferably 
enters a pipeline complete state 368 and then to the first header 
10 processing state 354 where reading and processing of the next 
window data packet is commenced. 

Referring to FIG. 10, the display engine 58 is preferably 
coupled to memory over a memory interface 37 0 and a CLUT over a 

15 CLUT interface 372. The display engine preferably includes the 
graphics FIFO 132 which receives the header packets and the 
graphics data from the memory controller over the memory interface. 
The graphics FIFO preferably provides received raw graphics data to 
the graphics converter 134 which converts the raw graphics data 

20 into the common compositing format. During the conversion of 
graphics format, the RGB to YUV converter 136 and data from the 
CLUT over the CLUT interface 372 are used to convert RGB formatted 
data and CLUT formatted data, respectively. 

25 The graphics converter preferably processes all of the window 

layers of each scan line in half the time, or less, of an 
interlaced display line, due to the need to have lines from both 
fields available in the SRAM for use by the graphics filter when 
frame mode filtering is enabled. The graphics converter operates 

30 at 81 MHz in one embodiment of the present invention, and the 
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graphics converter is able to process up to eight windows on each 
scan line and up to three full width windows. 

For example, with a 13.5 MHz display clock, if the graphics 
5 converter processes 81 Mpixels per second, it can convert three 
windows, each covering the width of the display, in half of the 
active display time of an interlaced scan line. In one embodiment 
of the present invention, the graphics converter processes all the 
window layers of each scan line in half the time of an interlaced 
10 display line, due to the need to have lines from both fields 
available in the SRAM for use by the graphics filter. In practice, 
there may be some more time available since the active display time 
leaves out the blanking time, while the graphics converter can 
operate continuously . 

15 

Graphics pixels are preferably read from the FIFO in raw 
graphics format, using one of the multiple formats allowed in the 
present invention and specified in the window descriptor. Each 
pixel may occupy as little as two bits or as much as 16 bits in the 

20 preferred embodiment. Each pixel is converted to a YUVa24 format 
(also referred to as aYUV 4:4:2:2 ), such as two adjacent pixels 
sharing a UV pair and having unique Y and alpha values, and each of 
the Y, U, V and alpha components occupying eight bits. The 
conversion process is generally dependent on the pixel format type 

25 and the alpha specification method, both of which are indicated by 
the window descriptor for the currently active window. Preferably, 
the graphics converter uses the CLUT memory to convert CLUT format 
pixels into RGB or YUV pixels. 

30 Conversions of RGB pixels may require conversion to YUV, and 

therefore, the graphics converter preferably includes a color space 
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converter. The color space converter preferably is accurate for 
all coefficients. If the converter is accurate to eight or nine 
bits it can be used to accurately convert eight bit per component 
graphics, such as CLUT entries with this level of accuracy or RGB24 
5 images. 



The graphics converter preferably produces one converted pixel 
per clock cycle, even when there are multiple graphics pixels 
packed into one word of data from the FIFO. Preferably the 

10 graphics processing clock, which preferably runs at 81 MHz, is used 
during the graphics conversion. The graphics converter preferably 
reads data from the FIFO whenever both conditions are met, 
including that the converter is ready to receive more data, and the 
FIFO has data ready. The graphics converter preferably receives an 

15 input from a graphics blender, which is the next block in the 
pipeline, which indicates when the graphics blender is ready to 
receive more converted graphics data. The graphics converter may 
stall if the graphics blender is not ready, and as a result, the 
graphics converter may not be ready to receive graphics data from 

20 the FIFO. 



The graphics converter preferably converts the graphics data 
into a YUValpha ("YUVa") format. This YUVa format includes YUV 
4:2:2 values plus an 8-bit alpha value for every pixel, and as such 

25 it occupies 24 bits per pixel; this format is alternately referred 
to as aYUV 4:4:2:2. The YUV4 4 4-to-YUV4 22 converter 138 converts 
graphics data with the aYUV 4:4:4:4 format from the graphics 
converter into graphics data with the aYUV 4:4:2:2 format and 
provides the data to the graphics blender 140. The YUV444-to- 

30 YUV422 converter preferably has a capacity of performing low pass 
filtering to filter out high frequency components when needed. The 
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graphics converter also sends and receives clock synchronization 
information to and from the graphics line buffers over a clock 
control interface 376. 

When provided with the converted graphics data, the graphics 
blender 140 preferably composites graphics windows into graphics 
line buffers over a graphics line buffer interface 374. The 
graphics windows are alpha blended into blended graphics and 
preferably stored in graphics line buffers. 

IV. Color Look-up Table Loading Mechanism 

A color look-up table ("CLUT") is preferably used to supply 
color and alpha values to the raw graphics data formatted to 
address information contents of the CLUT. For a window surface, 
based display, there may be multiple graphics windows on the same 
display screen with different graphics formats. For graphics 
windows using a color look-up table (CLUT) format, it may be 
necessary to load specific color look-up table entries from 
external memory to on-chip memory before the graphics window is 
displayed. 

The system preferably includes a display engine that processes 
graphics images formatted in a plurality of formats including a 
color look up table (CLUT) format. The system provides a data 
structure that describes the graphics in a window, provides a data 
structure that provides an indicator to load a CLUT, sorts the data 
structures into a list according to the location of the window on 
the display, and loads conversion data into a CLUT for converting 
the CLUT-f ormatted data into a different data format according to 
the sequence of data structures on the list. 



52 



WO 00/28518 



PCT/US99/26484 



In the preferred embodiment, each window on the display screen 
is described with a window descriptor. The same window descriptor 
is used to control GLUT loading as the window descriptor used to 
display graphics on screen. The window descriptor preferably 
defines the memory starting address of the graphics contents, the 
x position on the display screen, the width of the window, the 
starting vertical display line and end vertical display line, 
window layer, etc. The same window structure parameters and 
corresponding fields may be used to define the CLUT loading. For 
example, the graphics contents memory starting address may define 
CLUT memory starting address; the width of graphics window 
parameter may define the number of CLUT entries to be loaded; the 
starting vertical display line and ending vertical display line 
parameters may be used to define when to load the CLUT; and the 
window layer parameter may be used to define the priority of CLUT 
loading if several windows are displayed at the same time, i.e., on 
the same display line* 

In the preferred embodiment, only one CLUT is used. As such, 
the contents of the CLUT are preferably updated to display graphics 
windows with CLUT formatted data that is not supported by the 
current content of the CLUT. One of ordinary skill in the art 
would appreciate that it is straightforward to use more than one 
CLUT and switch back and forth between them for different graphics 
windows . 

In the preferred embodiment, the CLUT is closely associated 
with the graphics converter. In one embodiment of the present 
invention, the CLUT consists of one SRAM with 256 entries and 32 
bits per entry. In other embodiments, the number of entries and 
bits per entry may vary. Each entry contains three color 
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components; either RGB or YUV format, and an alpha component. For 
every CLUT-format pixel converted, the pixel data may be used as 
the address to the CLUT and the resulting value may be used by the 
converter to produce the YUVa (or alternatively RGBa) pixel value. 

5 

The CLUT may be re-loaded by retrieving new CLUT data via the 
direct memory access module when needed. It generally takes longer 
to re-load the CLUT than the time available in a horizontal 
blanking interval. Accordingly, in the preferred embodiment, a 
10 whole scan line time is allowed to re-load the CLUT. While the 
CLUT is being reloaded, graphics images in non-CLUT formats may be 
displayed. The CLUT reloading is preferably initiated by a window 
descriptor that contains information regarding CLUT reloading 
rather than a graphics window display information. 

15 

Referring to FIG. 11, the graphics CLUT 146 preferably 
includes a graphics CLUT controller 400 and a static dual-port RAM 
(SRAM) 402. The SRAM preferably has a size of 256 x 32 which 
corresponds to 256 entries in the graphics CLUT. Each entry in the 
20 graphics CLUT preferably has 32 bits composed of Y + U + V + alpha 
from the most significant bit to the least significant bit. The 
size of each field, including Y, U, V, and alpha, is preferably 
eight bits. 

25 The graphics CLUT preferably has a write port that is 

synchronized to a 81 MHz memory clock and a read port that may be 
asynchronous to the memory clock. The read port is preferably 
synchronous to the graphics processing clock, which runs preferably 
at 81 MHz, but not necessarily synchronized to the memory clock. 

30 During a read operation, the static dual-port RAM ("SRAM") is 
preferably addressed by a read address which is provided by 
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graphics data in the CLUT images. During the read operation, the 
graphics data is preferably output as read data 414 when a memory 
address in the CLUT containing that graphics data is addressed by 
a read address 412. 

5 

During write operations, the window controller preferably 
controls the write port with a CLUT memory request signal 404 and 
a CLUT memory write signal 408. CLUT memory data 410 is also 
preferably provided to the graphics CLUT via the direct memory 
10 access module from the external memory. The graphics CLUT 
controller preferably receives the CLUT memory data and provides 
the received CLUT memory data to the SRAM for writing. 

Referring to FIG. 12, an exemplary timing diagram shows 
15 different signals involved during a writing operation of the CLUT. 
The CLUT memory request signal 418 is asserted when the CLUT is to 
be re-loaded. A rising edge of the CLUT memory request signal 418 
is used to reset a write pointer associated with the write port. 
Then the CLUT memory write signal 420 is asserted to indicate the 
20 beginning of a CLUT re-loading operation. The CLUT memory data 422 
is provided synchronously to the 81 MHz memory clock 416 to be 
written to the SRAM. The write pointer associated with the write 
port is updated each time the CLUT is loaded with CLUT memory data. 

25 In the preferred embodiment, the process of reloading a CLUT 

is associated with the process of processing window descriptors 
illustrated in FIG. 8 since CLUT re-loading is initiated by a 
window descriptor. As shown in steps 324 and 328 of FIG. 8, if the 
window descriptor is determined to be for reloading CLUT in step 

30 324, the system in step 328 sends the CLUT data to the CLUT. The 
window descriptor for the CLUT reloading may appear anywhere in the 
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window descriptor list. Accordingly, the CLUT reloading may take 
place at any time whenever CLUT data is to be updated. 

Using the CLUT loading mechanism in one embodiment of the 
5 present invention, more than one window with different CLUT tables 
may be displayed on the same display line. In this embodiment, only 
the minimum required entries are preferably loaded into the CLUT, 
instead of loading all the entries every time. The loading of only 
the minimum required entries may save memory bandwidth and enables 

10 more functionality. The CLUT loading mechanism is preferably 
relatively flexible and easy to control, making it suitable for 
various applications. The CLUT loading mechanism of the present 
invention may also simplify hardware design, as the same state 
machine for the window controller may be used for CLUT loading. The 

15 CLUT preferably also shares the same DMA logic and layer /priority 
control logic as the window controller. 

V. Graphics Line Buffer Control Scheme 

20 In the preferred embodiment of the present invention, the 

system preferably blends a plurality of graphics images using line 
buffers. The system initializes a line buffer by loading the line 
buffer with data that represents transparent black, obtains control 
of a line buffer for a compositing operation, composites graphics 

25 contents into the line buffer by blending the graphics contents 
with the existing contents of the line buffer, and repeats the step 
of compositing graphics contents into the line buffer until all of 
the graphics surfaces for the particular line have been composited. 

30 The graphics line buffer temporarily stores composited 

graphics images (blended graphics) . A graphics filter preferably 
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uses blended graphics in line buffers to perform vertical filtering 
and scaling operations to generate output graphics images. In the 
preferred embodiment, the display engine composites graphics images 
line by line using a clock rate that is faster than the pixel 
5 display rate, and graphics filters run at the pixel display rate- 
In other embodiments, multiple lines of graphics images may be 
composited in parallel. In still other embodiments, the line 
buffers may not be needed. Where line buffers are used, the system 
may incorporate an innovative control scheme for providing the line 
10 buffers containing blended graphics to the graphics filter and 
releasing the line buffers that are used up by the graphics filter. 

The line buffers are preferably built with synchronous static 
dual-port random access memory ("SRAM") and dynamically switch 

15 their clocks between a memory clock and a display clock. Each line 
buffer is preferably loaded with graphics data using the memory 
clock and the contents of the line buffer is preferably provided to 
the graphics filter synchronously to the display clock. In one 
embodiment of the present invention, the memory clock is an 81 MHz 

20 clock used by the graphics converter to process graphics data while 
the display clock is a 13.5 MHz clock used to display graphics and 
video signals on a television screen. Other embodiments may use 
other clock speeds. 

25 Referring to FIG. 13, the graphics line buffer preferably 

includes a graphics line buffer controller 500 and line buffers 
504. The graphics line buffer controller 500 preferably receives 
memory clock buffer control signals 508 as well as display clock 
buffer control signals 510. The memory clock control signals and 

30 the display clock control signals are used to synchronize the 
graphics line buffers to the memory clock and the display clock, 



57 



WO 00/28518 PCT/US99/26484 - 

respectively. The graphics line buffer controller receives a clock 
selection vector 514 from the display engine to control which 
graphics line buffers are to operate in which clock domain. The 
graphics line buffer controller returns a clock enable vector to 
5 the display engine to indicate clock synchronization settings in 
accordance with the clock selection vector. 

In the preferred embodiment, the line buffers 504 include 
seven line buffers 506a-g. ' The line buffers temporarily store 

10 lines of YUVa24 graphics pixels that are used by a subsequent 
graphics filter. This allows for four line buffers to be used for 
filtering and scaling, two are available for progressing by one or 
two lines at the end of every line, and one for the current 
compositing operation. Each line buffer may store an entire 

15 display line. Therefore, in this embodiment, the total size of the 
line buffers is (720 pixels/display line) * (3 bytes/pixel) * (7 
lines) = 15,120 bytes. 

Each of the ports to the SRAM including line buffers is 24 
20 bits wide to accommodate graphics data in YUVa24 format in this 
embodiment of the present invention. The SRAM has one read port 
and one write port. One read port and one write port are used for 
the graphics blender interface, which performs a read-modif y-write 
typically once per clock cycle. In another embodiment of the 
25 present invention, an SRAM with only one port is used. In yet 
another embodiment, the data stored in the line buffers may be 
YUVa32 (4:4:4:4), RGBa32, or other formats. Those skilled in the 
art would appreciate that it is straightforward to vary the number 
of graphics line buffers, e.g., to use different number of taps for 
30 filter, the format of graphics data or the number of read and write 
ports for the SRAM. 
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The line buffers are preferably controlled by the graphics 
line buffer controller over a line buffer control interface 502. 
Over this interface, the graphics line buffer controller transfers 
5 graphics data to be loaded to the line buffers. The graphics 
filter reads contents of the line buffers over a graphics line 
buffer interface 516 and clears the line buffers by loading them 
with transparent black pixels prior to releasing them to be loaded 
with more graphics data for display. 

10 

Referring FIG . 14, a flow diagram of a process of using line 
buffers to provide composited graphics data from a display engine 
to a graphics filter is illustrated. After the graphics display 
system is reset in step 520, the system in step 522 receives a 

15 vertical sync (VSYNC) indicating a field start. Initially, all 
line buffers preferably operate in the memory clock domain. 
Accordingly, the line buffers are synchronized to the 81 MHz memory 
clock in one embodiment of the present invention. In other 
embodiments, the speed of the memory clock may be different from 81 

20 MHz, or the line buffers may not operate in the clock domain of the 
main memory. The system in step 524 preferably resets all line 
buffers by loading them with transparent black pixels. 

The system in step 526 preferably stores composited graphics 
25 data in the line buffers. Since all buffers are cleared at every 
field start by the display engine to the equivalent of transparent 
black pixels, the graphics data may be blended the same way for any 
graphics window, including the first graphics window to be blended. 
Regardless of how many windows are composited into a line buffer, 
30 including zero windows, the result is preferably always the correct 
pixel data. 
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The system in step 528 preferably detects a horizontal sync 
(HSYNC) which signifies a new display line. At the start of each 
display line, the graphics blender preferably receives a line 
5 buffer release signal from the graphics filter when one or more 
line buffers are no longer needed by the graphics filter. Since 
four line buffers are used with the four-tap graphics filter at any 
given time, one to three line buffers are preferably made available 
for use by the graphics blender to begin constructing new display 

10 lines in them. Once a line buffer release signal is recognized, an 
internal buffer usage register is updated and then clock switching 
is performed to enable the display engine to work on the newly 
released one to three line buffers. In other embodiments, the 
number of line buffers may be more or less than seven, and more or 

15 less than three line buffers may be released at a time. 

The system in step 534 preferably performs clock switching. 
Clock switching is preferably done in the memory clock domain by 
the display engine using a clock selection vector. Each bit of the 

20 clock selection vector preferably corresponds to one of the 
graphics line buffers. Therefore, in one embodiment of the present 
invention with seven graphics line buffers, there are seven bits in 
the clock selection vector. For example, a corresponding bit of 
logic 1 in the clock selection vector indicates that the line 

25 buffer operates in the memory clock domain while a corresponding 
bit of logic 0 indicates that the line buffer operates in the 
display clock domain. 

Other embodiments may have different numbers of line buffers 
30 and the number of bits in the clock selection vector may vary 
accordingly. Clock switching logic preferably switches between the 
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memory clock and the display clock in accordance 
selection vector. The clock selection vector is 
used to multiplex the memory clock buffer control 
display clock buffer control signals. 

5 

Since there is preferably no active graphics data at field and 
line starts, clock switching preferably is done at the field start 
and the line start to accommodate the graphics filter to access 
graphics data in real-time. At the field and line starts, clock 

10 switching may be done without causing glitches on the display side. 
Clock switching typically requires a dead cycle time. A clock 
enable vector indicates that the graphics line buffers are ready to 
synchronize to the clocks again. The clock enable vector is 
preferably the same size at the clock selection vector. The clock 

15 enable vector is returned to the display engine to be compared with 
the clock selection vector. 

During clock switching, the clock selection vector is sent by 
the display engine to the graphics line buffer block. The clocks 

20 are preferably disabled to ensure a glitch-free clock switching. 
The graphics line buffers send the clock enable vector to the 
display engine with the clock synchronization settings requested in 
the clock selection vector. The display engine compares contents 
of the clock selection vector and the clock enable vector. When 

25 the contents match, the clock synchronization is preferably turned 
on again. 

After the completion of clock switching during the video 
inactive region, the system in step 536 preferably provides the 
30 graphics data in the line buffers to the graphics filter for anti- 
flutter filtering, sample rate conversion (SRC) and display. At 



with the clock 
preferably also 
signals and the 
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the end of the current display line, the system looks for a VSYNC 
in step 538. If the VSYNC is detected, the current field has been 
completed, and therefore, the system in step 530 preferably 
switches clocks for all line buffers to the memory clock and resets 
5 the line buffers in step 524 for display of another field. If the 
VSYNC is not detected in step 538, the current display line is not 
the last display line of the current field. The system continues 
to step 528 to detect another HSYNC for processing and displaying 
of the next display line of the current field. 

10 

VI. Window Soft Horizontal Scrolling Mechanism 

Sometimes it is desirable to scroll a graphics window softly, 
e.g., display text that moves from left to right or from right to 
15 left smoothly on a television screen. There are some difficulties 
that may be encountered in conventional methods that seek to 
implement horizontal soft scrolling. 

Graphics memory buffers are conventionally implemented using 
20 low-cost DRAM, SDRAM, for example. Such memory devices are 
typically slow and may require each burst transfer to be within a 
page. Smooth (or soft) horizontal scrolling, however, preferably 
enables the starting address to be set to any arbitrary pixel. This 
may conflict with the transfer of data in bursts within the well- 
25 defined pages of DRAM. In addition, complex control logic may be 
required to monitor if page boundaries are to be crossed during the 
transfer of pixel maps for each step during soft horizontal 
scrolling . 

30 In the preferred embodiment, an implementation of a soft 

horizontal scrolling mechanism is achieved by incrementally 
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modifying the content of a window descriptor for a particular 
graphics window. The window soft horizontal scrolling mechanism 
preferably enables positioning the contents of graphics windows on 
arbitrary positions on a display line. 

5 

In an embodiment of the present invention, the soft horizontal 
scrolling of graphics windows is implemented based on an 
architecture in which each graphics window is independently stored 
in a normal graphics buffer memory device (SDRAM, EDO-DRAM, DRAM) 
10 as a separate object. Windows are composed on top of each other in 
real time as required. To scroll a window to the left or right, a 
special field is defined in the window descriptor that tells how 
many pixels are to be shifted to the left or right. 

15 The system according to the present invention provides a 

method of horizontally scrolling a display window to the left, 
which includes the steps of blanking out one or more pixels at a 
beginning of a portion of graphics data, the portion being aligned 
with a start address; and displaying the graphics data starting at 

20 the first non-blanked out pixel in the portion of the graphics data 
aligned with the start address. 

The system according to the present invention also provides a 
method of horizontally scrolling a display window to the right 

25 which includes the steps of moving a read pointer to a new start 
address that is immediately prior to a current start address, 
blanking out one or more pixels at a beginning of a portion of 
graphics data, the portion being aligned to the new start address, 
and displaying the graphics data starting at the first non-blanked 

30 out pixel in the portion of the graphics data aligned with the new 
start address. 
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In practice, each graphics window is preferably addressed 
using an integer word address. For example, if the memory system 
uses 32 bit words, then the address of the start of a window is 
defined to be aligned to a multiple of 32 bits, even if the first 
5 pixel that is desired to be displayed is not so aligned. Each 
graphics window also preferably has associated with it a horizontal 
offset parameter, in units of pixels, that indicates a number of 
pixels to be ignored, starting at the indicated starting address, 
before the active display of the window starts. In the preferred 

10 embodiment, the horizontal offset parameter is the blank start 
pixel value in the word 3 of the window descriptor. For example, 
if the memory system uses 32-bit words and the graphics format of 
a window uses 8 bits per pixel, each 32-bit word contains four 
pixels. In this case, the display of the window may ignore one, 

15 two or three pixels (8, 16, or 24 bits), causing an effective left 
shift of one, two, or three pixels. 

In the embodiment illustrated by the above example, the memory 
system uses 32-bit words. In other embodiments, the memory system 
20 may use more or less number of bits per word, such as 16 bits per 
word or 64 bits per word. In addition, pixels in other embodiments 
may have various different number of bits per pixel, such as 1, 2, 
4, 8, 16, 24 and 32. 

25 Referring to FIG. 15, in the preferred embodiment, a first 

pixel (e.g., the first 8 bits) 604 of a 32-bit word 600, which is 
aligned to the start address, is blanked out. The remaining three 
8-bit pixels, other than the blanked out first pixel, are 
effectively shifted to the left by one pixel. Prior to blanking 

30 out, a read pointer 602 points to the first bit of the 32-bit word. 
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After blanking out, the read pointer 602 points to the ninth bit of 
the 32-bit word. 

Further, a shift of four pixels is implemented by changing the 
start address by one to the next 32-bit word. Shifts of any number 
of pixels are thereby implemented by a combination of adjusting the 
starting word address and adjusting the pixel shift amount. The 
same mechanism may be used for any number of bits per pixel (1, 2, 
4, etc. ) and any memory word' size. 

To shift a pixel or pixels to the right, the shifting cannot 
be achieved simply by blanking some of the bits at the start 
address since any blanking at the start will simply have an effect 
of shifting pixels to the left. Further, the shifting to the right 
cannot be achieved by blanking some of the bits at the end of the 
last data word of a display line since display of a window starts 
at the start address regardless of the position of the last pixel 
to be displayed. 

Therefore, in one embodiment of the present invention, when 
the graphics display is to be shifted to the right, a read pointer 
pointing at the start address is preferably moved to an address 
that is just before the start address, thereby making that address 
the new start address. Then, a portion of the data word aligned 
with the new start address is blanked out. This provides the 
effect of shifting the graphics display to the right. 

For example, a memory system may use 32-bit words and the 
graphics format of a window may use 2 bits per pixel, e.g., a CLUT 
2 format. If the graphics display is to be shifted by a pixel to 
the right, the read pointer is moved to an address that is just 
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before the start address, and that address becomes a new start 
address. Then, the first 30 bits of the 32-bit word that is 
aligned with the new start address are blanked out. In this case, 
blanking out of a portion of the 32-bit word that is aligned with 
5 the new start address has the effect of shifting the graphics 
display to the right. 

Referring to FIG. 16, a 32-bit word 610 that is aligned with 
the starting address is shifted to the right by one pixel. The 32- 

10 bit word 610 has a CLUT 2 format, and therefore contains 16 pixels. 
A read pointer 612 points at the beginning of the 32-bit word 610. 
To shift the pixels in the 32-bit word 610 to the right, an address 
that is just before the start address is made a new start address. 
A 32-bit data word 618 is aligned with the new start address. Then, 

15 the first 30 bits (15 pixels) 616 of the 32-bit data word 618 
aligned with the new start address are blanked out. The read 
pointer 612 points at a new location, which is the 31 st bit of the 
new start address. The 31 st bit and the 32 nd bit of the new start 
address may constitute a pixel 618. Insertion of the pixel 618 in 

20 front of 16 pixels of the 32-bit data word 610 effectively shifts 
those 16 pixels to the right by one pixel. 

VII. Anti-Aliased Text and Graphics 

25 TV-based applications, such as interactive program guides, 

enhanced TV, TV navigators, and web browsing on TV frequently 
require the display of text and line-oriented graphics on the 
display. A graphical element or glyph generally represents an 
image of text or graphics. Graphical element may refer to text 

30 glyphs or graphics. In conventional methods of displaying text on 
TV or computer displays, graphical elements are rendered as arrays 
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of pixels (picture elements) with two states for every pixel, i.e. 
the foreground and background colors. 

In some cases the background color is transparent, allowing 
video or other graphics to show through. Due to the relatively low 
resolution of most present day TVs, diagonal and round edges of 
graphical elements generally show a stair-stepped appearance which 
may be undesirable; and fine details are constrained to appear as 
one or more complete pixels (dots), which may not correspond well 
to the desired appearance. The interlaced nature of TV displays 
causes horizontal edges of graphical elements, or any portion of 
graphical elements with a significant vertical gradient, to show 
a "f luttering" appearance with conventional methods. 

Some conventional methods blend the edges of graphical 
elements with background colors in a frame buffer, by first reading 
the color in the frame buffer at every pixel where the graphical 
element will be written, combining that value with the foreground 
color of the graphical element, and writing the result back to the 
frame buffer memory. This method requires there to be a frame 
buffer; it requires the frame buffer to use a color format that 
supports such blending operations, such as RGB24 or RGB16, and it 
does not generally support the combination of graphical elements 
over full motion video, as such functionality may require repeating 
the read, combine and write back function of all pixels of all 
graphical elements for every frame or field of the video in a 
timely manner. 

The system preferably displays a graphical element by 
filtering the graphical element with a low pass filter to generate 
a multi-level value per pixel at an intended final display 
resolution and uses the multi-level values as alpha blend values 
for the graphical element in the subsequent compositing stage. 
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In one embodiment of the present invention, a method of 
displaying graphical elements on televisions and other displays is 
used. A deep color frame buffer with, for example, 16, 24, or 32 
bits per pixel, is not required to implement this method since this 
method is effective with as few as two bits per pixel. Thus, this 
method may result in a significant reduction in both the memory 
space and the memory bandwidth required to display text and 
graphics. The method preferably provides high quality when 
compared with conventional methods of anti-aliased text, and 
produces higher display quality than is available with conventional 
methods that do not support anti-aliased text. 

Referring to FIG. 17, a flow diagram illustrates a process of 
providing very high quality display of graphical elements in one 
embodiment of the present invention. First, the bi-level graphical 
elements are filtered by the system in step 652. The graphical 
elements are preferably initially rendered by the system in step 
650 at a significantly higher resolution than the intended final 
display resolution, for example, four times the final resolution in 
both horizontal and vertical axes. The filter may be any suitable 
low pass filter, such as a "box" filter. The result of the 
filtering operation is a multi-level value per pixel at the 
intended display resolution. 

The number of levels may be reduced to fit the number of bits 
used in the succeeding steps. The system in step 654 determines 
whether the number of levels are to be reduced by reducing the 
number of bits used. If the system determines that the number of 
levels are to be reduced, the system in step 656 preferably reduces 
the number of bits. For example, the result of box-filtering 4 x 
4 super-sampled graphical elements normally results in 17 possible 
levels; these may be converted through truncation or other means to 
16 levels to match a 4 bit representation, or eight levels to match 
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a 3 bit representation, 
representation. The filter 
low pass filter function to 
interlaced display . 

5 

In step 658, the system preferably uses the resulting multi- 
level values, either with or without reduction in the number of 
bits, as alpha blend values, which are preferably pixel alpha 
component values, for the graphical elements in a subsequent 
10 compositing stage. The multi-level graphical element pixels are 
preferably written into a graphics display buffer where the values 
are used as alpha blend values when the display buffer is 
composited with other graphics and video images. 

15 In an alternate embodiment, the display buffer is defined to 

have a constant foreground color consistent with the desired 
foreground color of the text or graphics, and the value of every 
pixel in the display buffer is defined to be the alpha blend value 
for that pixel. For example, an Alpha-4 format specifies four bits 

20 per pixel of alpha blend value in a graphics window, where the 4 
bits define alpha blend values of 0/16, 1/16, 2/16, . . . , 13/16, 
14/16, and 16/16. The value 15/16 is skipped in this example in 
order to obtain the endpoint values of 0 and 16/16 (1) without 
requiring the use of an additional bit. In this example format, 

25 the display window has a constant foreground color which is 
specified in the window descriptor. 

In another alternate embodiment, the alpha blend value per 
pixel is specified for every pixel in the graphical element by 

30 choosing a CLUT index for every pixel, where the CLUT entry 
associated with every index contains the desired alpha blend value 
as part of the CLUT contents. For example, a graphical element 
with a constant foreground color and 4 bits of alpha per pixel can 
be encoded in a CLUT 4 format such that every pixel of the display 

35 buffer is defined to be a 4 bit CLUT index, and each of the 



or four levels to match a 2 bit 
may provide a required vertical axis 
provide anti-flutter filter effect for 
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associated 16 CLUT entries has the appropriate alpha blend value 
(0/16, 1/16, 2/16, 14/16, 16/16) as well as the (same) constant 

foreground color in the color portion of the CLUT entries. 

5 In yet another alternate embodiment, the alpha per pixel 

values are used to form the alpha portion of color + alpha pixels 
in the display buffer, such as alphaRGB ( 4 , 4 , 4 , 4 ) with 4 bits for 
each of alpha, Red, Green, and Blue, or alphaRGB32 with 8 bits for 
each component. This format does not require the use of a CLUT. 

10 

In still another alternate embodiment, the graphical element 
may or may not have a constant foreground color. The various 
foreground colors are processed using a low-pass filter as 
described earlier, and the outline of the entire graphical element 

15 (including all colors other than the background) is separately 
filtered also using a low pass filter as described. The filtered 
foreground color is used as either the direct color value in, e.g., 
an alphaRGB format (or other color space, such as alphaYUV) or as 
the color choice in a CLUT format, and the result of filtering the 

20 outline is used as the alpha per pixel value in either a direct 
color format such as alphaRGB or as the choice of alpha value per 
CLUT entry in a CLUT format. 

The graphical elements are displayed on the TV screen by 
25 compositing the display buffer containing the graphical elements 
with optionally other graphics and video contents while blending 
the subject display buffer with all layers behind it using the 
alpha per pixel values created in the preceding steps. 
Additionally, the translucency or opacity of the entire graphical 
30 element may be varied by specifying the alpha value of the display 
buffer via such means as the window alpha value that may be 
specified in a window descriptor. 
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VIII. Video Synchronization 

When a composite video signal (analog video) is received into 
the system, it is preferably digitized and separated into YUV (luma 
5 and chroma) components for processing. Samples taken for YUV are 
preferably synchronized to a display clock for compositing with 
graphics data at the video compositor. Mixing or overlaying of 
graphics with decoded analog video may require synchronizing the 
two image sources exactly. Undesirable artifacts such as jitter 

10 may be visible on the display unless a synchronization mechanism is 
implemented to correctly synchronize the samples from the analog 
video to the display clock. In addition, analog video often does 
not adhere strictly to the television standards such as NTSC and 
PAL. For example, analog video which originates in VCRs may have 

15 synchronization signals that are not aligned with chroma reference 
signals and also may have inconsistent line periods. Thus, the 
synchronization mechanism preferably should correctly synchronize 
samples from non-standard analog videos as well. 

20 The system, therefore, preferably includes a video 

synchronizing mechanism that includes a first sample rate converter 
for converting a sampling rate of a stream of video samples to a 
first converted rate, a filter for processing at least some of the 
video samples with the first converted rate, and a second sample 

25 rate converter for converting the first converted rate to a second 
converted rate. 

Referring to FIG. 18, the video decoder 50 preferably samples 
and synchronizes the analog video input. The video receiver 
30 preferably receives an analog video signal 706 into an analog-to- 
digital converter (ADC) 700 where the analog video is digitized. 
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The digitized analog video 708 is preferably sub-sampled by a 
chroma-locked sample rate converter (SRC) 708. A sampled video 
signal 710 is provided to an adaptive 2H comb filter /chroma 
demodulator/luma processor 702 to be separated into YUV (luma and 
5 chroma) components. In the 2H comb filter/chroma demodulator/luma 
processor 702, the chroma components are demodulated. In addition, 
the luma component is preferably processed by noise reduction, 
coring and detail enhancement operations. The adaptive 2H comb 
filter provides the sampled' video 712, which has been separated 

10 into luma and chroma components and processed, to a line-locked SRC 
704. The luma and chroma components of the sample video is 
preferably sub-sampled once again by the line-locked SRC and the 
sub-sampled video 714 is provided to a time base corrector (TBC) 
72. The time base corrector preferably provides an output video 

15 signal 716 that is synchronized to a display clock of the graphics 
display system. In one embodiment of the present invention, the 
display clock runs at a nominal 13.5 MHz. 

The synchronization mechanism preferably includes the chroma- 
20 locked SRC 70, the line-locked SRC 704 and the TBC 72. The chroma- 
locked SRC outputs samples that are locked to chroma subcarrier and 
its reference bursts while the line-locked SRC outputs samples that 
are locked to horizontal syncs. In the preferred embodiment, 
samples of analog video are over-sampled by the ADC 700 and then 
25 down-sampled by the chroma-locked SRC to four times the chroma sub- 
carrier frequency (Fsc) . The down-sampled samples are down-sampled 
once again by the line-locked SRC to line-locked samples with an 
effective sample rate of nominally 13.5 MHz. The time base 
corrector is used to align these samples to the display clock, 
30 which runs nominally at 13.5 MHz . 
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Analog composite video has a chroma signal frequency 
interleaved in frequency with the luma signal. In an NTSC standard 
video, this chroma signal is modulated on to the Fsc of 
approximately 3.579545 MHz , or exactly 227.5 times the horizontal 
5 line rate. The luma signal covers a frequency span of zero to 
approximately 4.2 MHz. One method for separating the luma from the 
chroma is to sample the video at a rate that is a multiple of the 
chroma sub-carrier frequency, and use a comb filter on the sampled 
data. This method generally imposes a limitation that the sampling 
10 frequency is a multiple of the chroma sub-carrier frequency (Fsc) . 

Using such a chroma-locked sampling frequency generally 
imposes significant costs and complications on the implementation, 
as it may require the creation of a sample clock of the correct 

15 frequency, which itself may require a stable, low noise 
controllable oscillator (e.g. a VCXO) in a control loop that locks 
the VCXO to the chroma burst frequency. Different sample 
frequencies are typically required for different video standards 
with different chroma subcarrier frequencies. Sampling at four 

20 times the subcarrier frequency, i.e. 14.318 MHz for NTSC standard 
and 17.72 MHz for PAL standard, generally requires more anti-alias 
filtering before digitization than is required when sampling at 
higher frequencies such as 27 MHz. In addition, such a chroma- 
locked clock frequency is often unrelated to the other frequencies 

25 in a large scale digital device, requiring multiple clock domains 
and asynchronous internal interfaces. 

In the preferred embodiment, however, the samples are not 
taken at a frequency that is a multiple of Fsc. Rather, in the 
30 preferred embodiment, an integrated circuit takes samples of the 
analog video at a frequency that is essentially arbitrary and that 
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is greater than four times the Fsc (4Fsc = 14.318 MHz). The 
sampling frequency preferably is 27 MHz and preferably is not 
locked to the input video signal in phase or frequency. The 
sampled video data then goes through the chroma-locked SRC that 
5 down-samples the data to an effective sampling rate of 4Fsc. This 
and all subsequent operations are preferably performed in digital 
processing in a single integrated circuit. 

The effective sample rate' of 4Fsc does not require a clock 
10 frequency that is actually at 4Fsc, rather the clock frequency can 
be almost any higher frequency, such as 27 MHz , and valid samples 
occur on some clock cycles while the overall rate of valid samples 
is equal to 4Fsc. The down-sampling (decimation) rate of the SRC 
is preferably controlled by a chroma phase and frequency tracking 
15 module. The chroma phase and frequency tracking module looks at 
the output of the SRC during the color burst time interval and 
continuously adjusts the decimation rate in order to align the 
color burst phase and frequency. The chroma phase and frequency 
tracking module is implemented as a logical equivalent of a phase 
20 locked loop (PLL) , where the chroma burst phase and frequency are 
compared in a phase detector to the effective sample rate, which is 
intended to be 4Fsc, and the phase and frequency error terms are 
used to control the SRC decimation rate. 

25 The decimation function is applied to the incoming sampled 

video, and therefore the decimation function controls the chroma 
burst phase and frequency that is applied to the phase detector. 
This system is a closed feedback loop (control loop) that functions 
in much the same way as a conventional PLL, and its operating 

30 parameters are readily designed in the same way as those of PLLs. 

Referring to FIG. 19, the chroma-locked SRC 70 preferably 
includes a sample rate converter (SRC) 730, a chroma tracker 732 
and a low pass filter (LPF) . The SRC 730 is preferably a polyphase 
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filter having time-varying coefficients. The SRC is preferably 
implemented with 35 phases and the conversion ratio of 35/66. The 
SRC 730 preferably interpolates by exactly 35 and decimates by (66 
+ epsilon) , i.e. the decimation rate is preferably adjustable 
5 within a range determined by the minimum and maximum values of 
epsilon, generally a small range. Epsilon is a first adjustment 
value, which is used to adjust the decimation rate of a first 
sample rate converter, i.e., the chroma-locked sample rate 
converter . 

10 

Epsilon is preferably generated by the control loop comprising 
the chroma tracker 732 and the LPF 734, and it can be negative, 
positive or zero. When the output samples of the SRC 730 are 
exactly frequency and phase locked to the color sub-carrier then 
15 epsilon is zero. The chroma tracker tracks phase and frequency of 
the chroma bursts and compares them against an expected pattern. 

In one embodiment of the present invention, the conversion 
rate of the chroma-locked SRC is adjusted so that, in effect, the 

20 SRC samples the chroma burst at exactly four times per chroma sub- 
carrier cycle. The SRC takes the samples at phases 0 degrees, 90 
degrees, 180 degrees and 270 degrees of the chroma sub-carrier 
cycle. This means that a sample is taken at every cycle of the 
color sub-carrier at a zero crossing, a positive peak, zero 

25 crossing and a negative peak, (0, +1, 0, -1) . If the pattern 
obtained from the samples is different from (0, +1, 0, -1), this 
difference is detected and the conversion ratio needs to be 
adjusted inside the control loop. 

30 When the output samples of the chroma-locked SRC are lower in 

frequency or behind in phase, e.g., the pattern looks like (-1, 0, 
+1, 0), then the chroma tracker 732 will make epsilon negative. 
When epsilon is negative, the sample rate conversion ratio is 
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higher than the nominal 35/66, and this has the effect " of 
increasing the frequency or advancing the phase of samples at the 
output of the chroma-locked SRC. When the output samples of the 
chroma-locked SRC are higher in frequency or leading in phase, 
e.g., the pattern looks like ( + 1, 0, -1, 0), then the chroma 
tracker 732 will make epsilon positive. When epsilon is positive, 
the sample rate conversion ratio is lower than the nominal 35/66, 
and this has the effect of decreasing the frequency or retarding 
the phase of samples out of the chroma-locked SRC. The chroma 
tracker provides error signal 736 to the LPF 734 that filters the 
error signal to filter out high frequency components and provides 
the filtered error signal to the SRC to complete the control loop. 

The sampling clock may run at the system clock frequency or at 
the clock frequency of the destination of the decoded digital 
video. If the sampling clock is running at the system clock, the 
cost of the integrated circuit may be lower than one that has a 
system clock and a sub-carrier locked video decoder clock. A one 
clock integrated circuit may also cause less noise or interference 
to the analog-to-digital converter on the IC. The system is 
preferably all digital, and does not require an external crystal or 
a voltage controlled oscillator. 

Referring to FIG. 20, an alternate embodiment of the chroma- 
locked SRC 70 preferably varies the sampling rate while the 
conversion rate is held constant. A voltage controlled oscillator 
(e.g., VCXO) 760 varies the sampling rate by providing a sampling 
frequency signal 718 to the ADC 700. The conversion rate in this 
embodiment is fixed at 35/66 in the SRC 750 which is the ratio 
between four times the chroma sub-carrier frequency and 27 MHz . 
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In this embodiment, the chroma burst signal at the output of 
the chroma-locked SRC is compared with the expected chroma burst 
signal in a chroma tracker 752. The error signals 756 from the 
comparison between the converted chroma burst and the expected 
5 chroma burst are passed through a low pass filter 754 and then 
filtered error signals 758 are provided to the VCXO 760 to control 
the oscillation frequency of the VCXO. The oscillation frequency 
of the VCXO changes in response to the voltage level of the 
provided error signals. Use of input voltage to control the 
10 oscillation frequency of a VCXO is well known in the art. The 
system as described here is a form of a phase locked loop (PLL), 
the design and use of which is well known in the art. 

After the completion of chroma-luma separation and other 
processing to the chroma and luma components, the samples with the 
effective sample rate of 4 Fsc (i.e. 4 times the chroma subcarrier 
frequency) are preferably decimated to samples with a sample rate 
of nominally 13.5 MHz through the use of a second sample rate 
converter. Since this sample rate is less than the electrical 
clock frequency of the digital integrated circuit in the preferred 
embodiment, only some clock cycles carry valid data. In this 
embodiment, the sample rate is preferably converted to 13.5 MHz , 
and is locked to the horizontal line rate through the use of 
horizontal sync signals. Thus, the second sample rate converter is 
a line-locked sample rate converter (SRC) . 

The line-locked sample rate converter converts the current 
line of video to a constant (Pout) number of pixels. This constant 
number of pixels Pout is normally 858 for ITU-R BT.601 applications 
30 and 780 for NTSC square pixel applications. The current line of 
video may have a variable number of pixels (Pin) . In order to do 
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this conversion from a chroma-locked sample rate, the following 
steps are performed. The number of input samples Pin of the 
current line of video is accurately measured. This line 
measurement is used to calculate the sample rate conversion ratio 
needed to convert the line to exactly Pout samples. An adjustment 
value to the sample rate conversion ratio is passed to a sample 
rate converter module in the line-locked SRC to implement the 
calculated sample rate conversion ratio for the current line. The 
sample conversion ratio is calculated only once for each line. 
Preferably, the line-locked SRC also scales YUV components to the 
proper amplitudes required by ITU-R BT.601. 

The number of samples detected in a horizontal line may be 
more or less if the input video is a non-standard video. For 
example, if the incoming video is from a VCR, and the sampling rate 
is four times the color sub-carrier frequency (4Fsc) , then the 
number of samples taken between two horizontal syncs may be more or 
less than 910, where 910 is the number of samples per line that is 
obtained when sampling NTSC standard video at a sampling frequency 
of 4Fsc. For example, the horizontal line time from a VCR may vary 
if the video tape has been stretched. 

The horizontal line time may be accurately measured by 
detecting two successive horizontal syncs. Each horizontal sync is 
preferably detected at the leading edge of the horizontal sync. In 
other embodiments, the horizontal syncs may be detected by other 
means. For example, the shape of the entire horizontal sync may be 
looked at for detection. In the preferred embodiment, the sample 
rate for each line of video has been converted to four times the 
color sub-carrier frequency (4Fsc) by the chroma-locked sample rate 
converter. The measurement of the horizontal line time is 
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preferably done at two levels of accuracy, an integer pixel 
accuracy and a sub-sample accuracy. 

The integer pixel accuracy is preferably done by counting the 
5 integer number of pixels that occur between two successive sync 
edges. The sync edge is presumed to be detected when the data 
crosses some threshold value. For example, in one embodiment of 
the present invention, the analog-to-digital converter (ADC) is a 
10-bit ADC, i.e., converts an input analog signal into a digital 

10 signal with (2*10 - 1 = 1023) scale levels. In this embodiment, 
the threshold value is chosen to represent an appropriate slicing 
level for horizontal sync in the 10-bit number system of the ADC; 
a typical value for this threshold is 128. The negative peak (or 
a sync tip) of the digitized video signal normally occurs during 

15 the sync pulses. The threshold level would normally be set such 
that it occurs at approximately the mid-point of the sync pulses. 
The threshold level may be automatically adapted by the video 
decoder, or it may be set explicitly via a register or other means. 

20 The horizontal sync tracker preferably detects the horizontal 

sync edge to a sub-sample accuracy of (1/16) th of a pixel in order 
to more accurately calculate the sample rate conversion. The 
incoming samples generally do not include a sample taken exactly at 
the threshold value for detecting horizontal sync edges. The 

25 horizontal sync tracker preferably detects two successive samples, 
one of which has a value lower than the threshold value and the 
other of which has a value higher than the threshold value. 

After the integer pixel accuracy is determined (sync edge has 
30 been detected) the sub-pixel calculation is preferably started. The 
sync edge of a horizontal sync is generally not a vertical line, 
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but has a slope. In order to remove noise, the video signal goes 
through a low pass filter. The low pass filter generally decreases 
sharpness of the transition, i.e., the low pass filter may make the 
transition from a low level to a high level last longer. 

The horizontal sync tracker preferably uses a sub-sample 
interpolation technique to obtain an accurate measurement of sync 
edge location by drawing a straight line between the two successive 
samples of the horizontal sync' signal just above and just below the 
presumed threshold value to determine where the threshold value has 
been crossed. 

Three values are preferably used to determine the sub-sample 
accuracy. The three values are the threshold level (T) , the value 
of the sample that crossed the threshold level (V2) and the value 
of the previous sample that did not cross the threshold level (VI) . 
The sub-sample value is the ratio of ( T - VI ) / ( V2 - VI ) . In 
the present embodiment a division is not performed. The difference 
(V2-V1) is divided by 16 to make a variable called DELTA. VI is 
then incremented by DELTA until it exceeds the threshold T. The 
number of times that DELTA is added to VI in order to make it 
exceed the threshold (T) is the sub-pixel accuracy in terms of 
l/16 th of a pixel. 

For example, if the threshold value T is presumed to be 146 
scale levels, and if the values VI and V2 of the two successive 
samples are 140 and 156, respectively, the DELTA is calculated to 
be 1, and the crossing of the threshold value is determined through 
interpolation to be six DELTAS away from the first of the two 
successive samples. Thus, if the sample with value 140 is the nth 
sample and the sample with the value 156 is the (n+l)th sample, the 
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(n+ ( 6/16) ) th sample would have had the threshold value. Since the 
horizontal sync preferably is presumed to be detected at the 
threshold value of the sync edge, a fractional sample, i.e., 6/16 
sample, is added to the number of samples counted between two 
5 successive horizontal syncs. 

In order to sample rate convert the current number of input 
pixels Pin to the desired output pixels Pout, the sample rate 
converter module has a sample rate conversion ratio of Pin/Pout. 

10 The sample rate converter module in the preferred embodiment of the 
line-locked sample rate converter is a polyphase filter with time- 
varying coefficients. There is a fixed number of phases (I) in the 
polyphase filter. In the preferred embodiment, the number of 
phases (I) is 33. The control for the polyphase filter is the 

15 decimation rate (d__act) and a reset phase signal. The line 
measurement Pin is sent to a module that converts it to a 
decimation rate d_act such that I/d__act (33/d_act) is equal to 
Pin/Pout. The decimation rate d_act is calculated as follows: 
d_act - (I/Pout)* Pin. 

20 

If the input video line is the standardized length of time and 
the four times the color sub-carrier is the standardized frequency 
then Pin will be exactly 910 samples. This gives a sample rate 
conversion ratio of (858/910) . In the present embodiment the 

25 number of phases (the interpolation rate) is 33. Therefore the 
nominal decimation rate for NTSC is 35 ( = (33/858) * 910 ) . This 
decimation rate d_act may then be sent to the sample rate converter 
module. A reset phase signal is sent to the sample rate converter 
module after the sub-sample calculation has been done and the 

30 sample rate converter module starts processing the current video 
line. In the preferred embodiment, only the active portion of 
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video is processed and sent on to a time base corrector. This 
results in a savings of memory needed. Only 720 samples of active 
video are produced as ITU-R BT.601 output sample rates. In other 
embodiments, the entire horizontal line may be processed and 
produced as output. 



In the preferred embodiment, the calculation of the decimation 
rate d_act is done somewhat differently from the equation d_act = 
(I/Pout) * Pin. The results are the same, but there are savings to 
hardware. The current line length, Pin, will have a relatively 
small variance with respect to the nominal line length. Pin is 
nominally 910. It typically varies by less than 62. For NTSC, 
this variation is less than 5 microseconds. The following 
calculation is done: d_act - ( (I/Pout) * (Pin - Pin_nominal) ) + 
d act nominal 



This preferably results in a hardware savings for the same 
level of accuracy. The difference (Pin - Pin_nominal) may be 
represented by fewer bits than are required to represent Pin so a 
smaller multiplier can be used. For NTSC, d_act_nominal is 35 and 
Pin__nominal is 910. The value (I/Pout) * (Pin - Pin_nominal) may now 
be called a delta_dec (delta decimation rate) or a second 
adjustment value. 



Therefore, in order to maintain the output sample rate of 858 
samples per horizontal line, the conversion rate applied preferably 
is 33/(35 + delta__dec) where the samples are interpolated by 33 and 
decimated by (35 + delta_dec) . A horizontal sync tracker 
preferably detects horizontal syncs, accurately counts the number 
of samples between two successive horizontal syncs and generates 
delta dec. 
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If the number of samples between two successive horizontal 
syncs is greater than 910, the horizontal sync tracker generates a 
positive delta_dec to keep the output sample rate at • 858 samples 
5 per horizontal line. On the other hand, if the number of samples 
between two successive horizontal syncs is less than 910, the 
horizontal sync tracker generates a negative delta_dec to keep the 
output sample rate at 858 samples per horizontal line. 

10 For PAL standard video, the horizontal sync tracker generates 

the delta_dec to keep the output sample rate at 8 64 samples per 
horizontal line. 

In summary, the position of each horizontal sync pulse is 
15 determined to sub-pixel accuracy by interpolating between two 
successive samples, one of which being immediately below the 
threshold value and the other being immediately above the threshold 
value. The number of samples between the two successive horizontal 
sync pulses is preferably calculated to sub-sample accuracy by 
20 determining the positions of two successive horizontal sync pulses, 
both to sub-pixel accuracy. When calculating delta_dec, the 
horizontal sync tracker preferably uses the difference between 910 
and the number of samples between two successive horizontal syncs 
to reduce the amount of hardware needed. 

25 

In an alternate embodiment, the decimation rate adjustment 
value, delta_dec, which is calculated for each line, preferably 
goes through a low pass filter before going to the sample rate 
converter module. One of the benefits of this method is filtering 
30 of variations in the line lengths of adjacent lines where the 
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variations may be caused by noise that affects the accuracy of the 
measurement of the sync pulse positions. 

In another alternative embodiment, the input sample clock is 
5 not free running, but is instead line-locked to the input analog 
video, preferably 27 MHz. The chroma-locked sample rate converter 
converts the 27 MHz sampled data to a sample rate of four times the 
color sub-carrier frequency. The analog video signal is 

demodulated to luma. and chroma component video signals, preferably 

10 using a comb filter. The luma and chroma component video signals 
are then sent to the line-locked sample rate converter where they 
are preferably converted to a sample rate of 13.5 MHz. In this 
embodiment the 13.5 MHz sample rate at the output may be exactly 
one-half of the 27 MHz sample rate at the input. The conversion 

15 ratio of the line-locked sample rate converter is preferably 
exactly one-half of the inverse of the conversion ratio performed 
by the chroma-locked sample rate converter. 

Referring to FIG . 21, the line-locked SRC 704 preferably 
20 includes an SRC 770 which preferably is a polyphase filter with 
time varying coefficients. The number of phases is preferably 
fixed at 33 while the nominal decimation rate is 35. In other 
words, the conversion ratio used is preferably 33/(35 + delta dec) 
where delta_dec may be positive or negative. The delta dec is a 
25 second adjustment value, which is used to adjust the decimation 
rate of the second sample rate converter. Preferably, the actual 
decimation rate and phase are automatically adjusted for each 
horizontal line so that the number of samples per horizontal line 
is 858 (720 active Y samples and 360 active U and V samples) and 
30 the phase of the active video samples is aligned properly with the 
horizontal sync signals. 
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In the preferred embodiment, the decimation (down-sampling) 
rate of the SRC is preferably controlled by a horizontal sync 
tracker 772. Preferably, the horizontal sync tracker adjusts the 
decimation rate once per horizontal line in order to result in a 
correct number and phase of samples in the interval between 
horizontal syncs. The horizontal sync tracker preferably provides 
the adjusted decimation rate to the SRC 770 to adjust the 
conversion ratio. The decimation rate is preferably calculated to 
achieve a sub-sample accuracy of 1/16. Preferably, the line-locked 
SRC 704 also includes a YUV scaler 780 to scale YUV components to 
the proper amplitudes required by ITU-R BT.601. 

The time base corrector (TBC) preferably synchronizes the 
samples having the line-locked sample rate of nominally 13.5 MHz to 
the display clock that runs nominally at 13.5 MHz. Since the 
samples at the output of the TBC are synchronized to the display 
clock, passthrough video may be provided to the video compositor 
without being captured first. 

To produce samples at the sample rate of nominally 13.5 MHz, 
the composite video may be sampled in any conventional way with a 
clock rate that is generally used in the art. Preferably, the 
composite video is sampled initially at 27 MHz, down sampled to the 
sample rate of 14.318 MHz by the chroma-locked SRC, and then down 
sampled to the sample rate of nominally 13.5 MHz by the line-locked 
SRC. During conversion of the sample rates, the video decoder uses 
for timing the 27 MHz clock that was used for input sampling. The 
27 MHz clock, being free-running, is not locked to the line rate 
nor to the chroma frequency of the incoming video. 
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In the preferred embodiment, the decoded video samples are 
stored in a FIFO the size of one display line of active video at 
13.5 MHz, i.e., 720 samples with 16 bits per sample or 1440 bytes. 
Thus, the maximum delay amount of this FIFO is one display line 
time with a normal, nominal delay of one-half a display line time. 
In the preferred embodiment, video samples are outputted from the 
FIFO at the display clock rate that is nominally 13.5 MHz . Except 
for vertical syncs of the input video, the display clock rate is 
unrelated to the timing of ' the input video. In alternate 
embodiments, larger or smaller FIFOs may be used. 

Even though the effective sample rate and the display clock 
rate are both nominally 13.5 MHz the rate of the sampled video 
entering the FIFO and the display rate are generally different. 
This discrepancy is due to differences between the actual 
frequencies of the effective input sample rate and the display 
clock. For example, the effective input sample rate is nominally 
13.5 MHz but it is locked to operate at 858 times the line rate of 
the video input, while the display clock operates nominally at 13.5 
MHz independently of the line rate of the video input. 

Since the rates of data entering and leaving the FIFO are 
typically different, the FIFO will tend to either fill up or become 
empty, depending on relative rates of the entering and leaving 
data. In one embodiment of the present invention, video is 
displayed with an initial delay of one-half a horizontal line time 
at the start of every field. This allows the input and output 
rates to differ up to the point where the input and output 
horizontal phases may change by up to one-half a horizontal line 
time without causing any glitches at the display. 
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The FIFO is preferably filled up to approximately one-half 
full during the first active video line of every field prior to 
taking any output video. Thus, the start of each display field 
follows the start of every input video field by a fixed delay that 
is approximately equal to one-half the amount of timefor filling 
the entire FIFO. As such, the initial delay at the start of every 
field is one-half a horizontal line time in this embodiment, but 
the initial delay may be different in other embodiments. 

Referring to FIG. 22, the time base corrector (TBC) 72 
includes a TBC controller 164 and a FIFO 166. The FIFO 166 
receives an input video 714 at nominally 13.5 MHz locked to the 
horizontal line rate of the input video and outputs a delayed input 
video as an output video 716 that is locked to the display clock 
that runs nominally at 13.5 MHz. The initial delay between the 
input video and the delayed input video is half a horizontal line 
period of active video, e.g., 53.5 \is per active video in a 
horizontal line / 2 = 26.75 |ns for NTSC standard video. 

The TBC controller 164 preferably generates a vertical sync 
(VSYNC) for display that is delayed by one-half a horizontal line 
from an input VSYNC. The TBC controller 164 preferably also 
generates timing signals such as NTSC or PAL standard timing 
signals. The timing signals are preferably derived from the VSYNC 
generated by the TBC controller and preferably include horizontal 
sync. The timing signals are not affected by the input video, and 
the FIFO is read out synchronously to the timing signals. Data is 
read out of the FIFO according to the timing at the display side 
while the data is written into the FIFO according to the input 
timing. A line reset resets the FIFO write pointer to signal a new 
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line. A read pointer controlled by the display side is updated by 
the display timing. 

As long as the accumulated change in FIFO fullness, in either 
5 direction, is less than one-half a video line, the FIFO will 
generally neither underflow nor overflow during the video field. 
This ensures correct operation when the display clock frequency is 
anywhere within a fairly broad range centered on the nominal 
frequency. Since the process is repeated every field, the FIFO 
10 fullness changes do not accumulate beyond one field time. 

Referring to FIG. 23, a flow diagram of a process using the 
TBC 72 is illustrated. The process resets in step 782 at system 
start up. The system preferably checks for vertical sync (VSYNC) 

15 of the input video in step 784. After receiving the input VSYNC, 
the system in step 786 preferably starts counting the number of 
incoming video samples. The system preferably loads the FIFO in 
step 788 continuously with the incoming video samples. While the 
FIFO is being loaded, the system in step 790 checks if enough 

20 samples have been received to fill the FIFO up to a half full 
state . 

When enough samples have been received to fill the FIFO to the 
half full state, the system in step 792 preferably generates timing 

25 signals including horizontal sync to synchronize the output of the 
TBC to the display clock. The system in step 794 preferably 
outputs the content of the FIFO continuously in sync with the 
display clock. The system in step 796 preferably checks for 
another input VSYNC. When another input vertical sync is detected, 

30 the system starts counting the number of input video samples again 
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and starts outputting output video samples when enough input video 
samples have been received to make the FIFO half full. 

In other embodiments of the present invention, the FIFO size 
may be smaller or larger. The minimum size acceptable is 
determined by the maximum expected difference in the video source 
sample rate and the display sample rate. Larger FIFOs allow for 
greater variations in sample rate timing, however at greater 
expense. For any chosen FIFO size, the logic that generates the 
sync signal that initiates display video fields should incur a 
delay from the input video timing of one-half the delay of the 
entire FIFO as described above. However, it is not required that 
the delay be one-half the delay of the entire FIFO. 

IX. Video Scaler 

In certain applications of graphics and video display 
hardware, it may be necessary or desirable to scale the size of a 
motion video image either upwards or downwards. It may also be 
desirable to minimize memory usage and memory bandwidth demands. 
Therefore it is desirable to scale down before writing to memory, 
and to scale up after reading from memory, rather than the other 
way around in either case. Conventionally there is either be 
separate hardware to scale down before writing to memory and to 
scale up after reading from memory, or else all scaling is done in 
one location or the other, such as before writing to memory, even 
if the scaling direction is upwards. 

In the preferred embodiment, a video scaler performs both 
scaling-up and scaling-down of either digital video or digitized 
analog video. The video scaler is preferably configured such that 
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it can be used for either scaling down the size of video images 
prior to writing them to memory or for scaling up the size of video 
images after reading them from memory. The size of the video 
images are preferably downscaled prior to being written to memory 
5 so that the memory usage and the memory bandwidth demands are 
minimized. For similar reasons, the size of the video images are 
preferably upscaled after reading them from memory. 

In the former case, the video scaler is preferably in the 
10 signal path between a video input and a write port of a memory 
controller. In the latter case, the video scaler is preferably in 
the signal path between a read port of the memory controller and a 
video compositor. Therefore, the video scaler may be seen to exist 
in two distinct logical places in the design, while in fact 
15 occupying only one physical implementation. 

This function is preferably achieved by arranging a 
multiplexing function at the input of the scaling engine, with one 
input to the multiplexer being connected to the video input port 

20 and the other connected to the memory read port. The memory write 
port is arranged with a multiplexer at its input, with one input to 
the multiplexer connected to the output of the scaling engine and 
the other connected to the video input port. The display output 
port is arranged with a multiplexer at its input, with one 

25 connected to the output of the scaling engine and the other input 
connected to the output of the memory read port. 

In the preferred embodiment, there are different clock domains 
associated with the video input and the display output functions of 
30 the chip. The video scaling engine uses a clock that is selected 
between the video input clock and the display output clock (display 
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clock) . The clock selection uses a glitch-free clock selection 
logic, i.e. a circuit that prevents the creation of extremely 
narrow clock pulses when the clock selection is changed. The read 
and write interfaces to memory both use asynchronous interfaces 
5 using FIFOs, so the memory clock domain may be distinct from both 
the video input clock domain and the display output clock domain. 

Referring to FIG. 24, a flow diagram illustrates a process of 
alternatively upscaling or downscaling the video input 800. The 

10 system in step 802 preferably selects between a downscaling 
operation and an upscaling operation. If the downscaling operation 
is selected, the system in step 804 preferably downscales the input 
video prior to capturing the input video in memory in step 806. If 
the upscaling operation is selected in step 802, the system in step 

15 806 preferably captures the input video in memory without scaling 
it . 

Then the system in step 808 outputs the downscaled video as 
downscaled output 810. The system in step 808, however, sends non- 
20 scaled video in the upscale path to be upscaled in step 812. The 
system in step 812 upscales the non-scaled video and outputs it as 
upscaled video output 814. 

The video pipeline preferably supports up to one scaled video 
25 window and one passthrough video window, plus one background color, 
all of which are logically behind the set of graphics windows. The 
order of these windows, from back to front, is fixed as background, 
then passthrough, then scaled video. The video windows are 
preferably always in YUV format, although they can be in either 
30 4:2:2 or 4:2:0 variants of YUV. Alternatively they can be in RGB 
or other formats. 
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When digital video, e.g., MPEG is provided to the graphics 
display system or when analog video is digitized, the digital video 
or the digitized analog video is provided to a video compositor 
5 using one of three signal paths, depending on processing 
requirements. The digital video and the digitized analog video are 
provided to the video compositor as passthrough video over a 
passthrough path, as upscaled video over an upscale path and a 
downscaled video ever a downscale path. 

10 

Either of the digital video or the analog video may be 
provided to the video compositor as the passthrough video while the 
other of the digital video or the analog video is provided as an 
upscaled video or a downscaled video. For example, the digital 

15 video may be provided to the video compositor over the passthrough 
path while, at the same time, the digitized analog video is 
downscaled and provided to the video compositor over the downscale 
path as a video window. In one embodiment of the present invention 
where the scaler engine is shared between the upscale path and the 

20 downscale path, the scaler engine may upscale video in either the 
vertical or horizontal axis while downscaling video in the other 
axis. However, in this embodiment, an upscale operation and a 
downscale operation on the same axis are not performed at the same 
time since only one filter is used to perform both upscaling and 

25 downscaling for each axis. 

Referring to FIG. 24 a single video scaler 52 preferably 
performs both the downscaling and upscaling operations. In 
particular, signals of the downscale path only are illustrated. The 
30 video scaler 52 includes a scaler engine 182, a set of line buffers 
178, a vertical coefficient memory 180A and a horizontal 
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coefficient memory 180B. The scaler engine 182 is implemented as 
a set of two polyphase filters, one for each of horizontal and 
vertical dimensions . 

5 In one embodiment of the present invention, the vertical 

polyphase filter is a four-tap filter with programmable 
coefficients from the vertical coefficient memory 180A. In other 
embodiments, the number of taps in the vertical polyphase filter 
may vary. In one embodiment of the present invention, the 
10 horizontal polyphase filter is an eight-tap filter with 
programmable coefficients from the horizontal coefficient memory 
180B. In other embodiments, the number of taps in the horizontal 
polyphase filter may vary. 

15 The vertical and the horizontal coefficient memories may be 

implemented in SRAM or any other suitable memory. Depending on the 
operation to be performed, e.g. a vertical or horizontal axis, and 
scaling-up or scaling-down, appropriate filter coefficients are 
used, respectively, from the vertical and horizontal coefficient 

20 memories. Selection of filter coefficients for scaling-up and 
scaling-down operations are well known in the art. 

The set of line buffers 178 are used to provide input of video 
data to the horizontal and vertical polyphase filters. In this 

25 embodiment, three line buffers are used, but the number of the line 
buffers may vary in other embodiments. In this embodiment, each of 
the three line buffers is used to provide an input to one of the 
taps of the vertical polyphase filter with four taps. The input 
video is provided to the fourth tap of the vertical polyphase 

30 filter. A shift register having eight cells in series is used to 
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provide inputs to the eight taps of the horizontal polyphase 
filter, each cell providing an input to one of the eight taps. 

In this embodiment, a digital video signal 820 and a digitized 
5 analog signal video 822 are provided to a first multiplexer 168 as 
first and second inputs. The first multiplexer 168 has two 
outputs. A first output of the first multiplexer is provided to 
the video compositor as a pass through video 18 6. A second output 
of the first multiplexer is provided to a first input of a second 
10 multiplexer 176 in the downscale path. 

In the downscale path, the second multiplexer 176 provides 
either the digital video or the digitized analog video at the 
second multiplexer's first input to the video scaler 52. The video 

15 scaler provides a downscaled video signal to a second input of a 
third multiplexer 162. The third multiplexer provides the 
downscaled video to a capture FIFO 158 which stores the captured 
downscaled video. The memory controller 126 takes the captured 
downscaled video and stores it as a captured downscaled video image 

20 into a video FIFO 148. An output of the video FIFO is coupled to 
a first input of a fourth multiplexer 188. The fourth multiplexer 
provides the output of the video FIFO, which is the captured 
downscaled video image, as an output 824 to the graphics 
compositor, and this completes the downscale path. Thus, in the 

25 downscale path, either the digital video or the digitized analog 
video is downscaled first, and then captured. 

FIG. 26 is similar to FIG. 25, but in FIG. 26, signals of the 
upscale path are illustrated. In the upscale path, the third 
30 multiplexer 162 provides either the digital video 820 or the 
digitized analog video 822 to the capture FIFO 158 which captures 
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and stores input as a captured video image. This captured video 
image is provided to the memory controller 126 which takes it and 
provides to the video FIFO 148 which stores the captured video 
image . 

5 

An output of the video FIFO 148 is provided to a second input 
of the second multiplexer 176. The second multiplexer provides the 
captured video image to the video scaler 52. The video scaler 
scales up the captured video image and provides it to a second 
10 input of the fourth multiplexer 188 as an upscaled captured video 
image. The fourth multiplexer provides the upscaled captured video 
image as the output 824 to the video compositor. Thus, in the 
upscale path, either the digital video or the digitized analog 
video is captured first, and then upscaled. 

15 

Referring to FIG. 27, FIG. 27 is similar to FIG. 25 and FIG. 
26, but in FIG. 27, signals of both the upscale path and the 
downscale path are illustrated. 

20 X. Blending of Graphics and Video Surfaces 

The graphics display system of the present invention is 
capable of processing an analog video signal, a digital video 
signal and graphics data simultaneously. In the graphics display 

25 system, the analog and digital video signals are processed in the 
video display pipeline while the graphics data is processed in the 
graphics display pipeline. After the processing of the video 
signals and the graphics data have been completed, they are blended 
together at a video compositor. The video compositor receives 

30 video and graphics data from the video display pipeline and the 
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graphics display pipeline, respectively, and outputs to the video 
encoder ("VEC") . 

The system may employ a method of compositing a plurality of 
5 graphics images and video, which includes blending the plurality of 
graphics images into a blended graphics image, combining a 
plurality of alpha values into a plurality of composite alpha 
values, and blending the blended graphics image and the video using 
the plurality of composite alpha values. 

10 

Referring to FIG. 28, a flow diagram of a process of blending 
video and graphics surfaces is illustrated. The graphics display 
system resets in step 902. In step 904, the video compositor 
blends the passthrough video and the background color with the 

15 scaled video window, using the alpha value which is associated with 
the scaled video window. The result of this blending operation is 
then blended with the output of the graphics display pipeline. The 
graphics output has been pre-blended in the graphics blender in 
step 904 and filtered in step 906, and blended graphics contain the 

20 correct alpha value for multiplication by the video output. The 
output of the video blend function is multiplied by the video alpha 
which is obtained from the graphics pipeline and the resulting 
video and graphics pixel data stream are added together to produce 
the final blended result. 

25 

In general, during blending of different layers of graphics 
and/or video, every layer {LI, L2, L3...Ln}, where LI is the back- 
most layer, each layer is blended with the composition of all of 
the layers behind it, beginning with L2 being blended on top of LI. 
30 The intermediate result R(i) from the blending of pixels P(i) of 
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layer L(i) over the pixels P(i-l) of layer L(i-l) using alpha value 
A(i) is: R(i) = A(i) * P(i) + (1- A(i)) * P(i-l). 

The alpha values {A(i) } are in general different for every 
layer and for every pixel of every layer. However, in some 
important applications, it is not practical to apply this formula 
directly, since some layers may need to be processed in spatial 
dimensions (e.g. 2 dimensional filtering or scaling) before they 
can be blended with the layer or layers behind them. While it is 
generally possible to blend the layers first and then perform the 
spatial processing, that would result in processing the layers that 
should not be processed if these layers are behind the subject 
layer that is to be processed. Processing of the layers that are 
not to be processed may be undesirable. 

Processing the subject layer first would generally require a 
substantial amount of local storage of the pixels in the subject 
layer, which may be prohibitively expensive. This problem is 
significantly exacerbated when there are multiple layers to be 
processed in front of one or more layers that are not to be 
processed. In order to implement the formula above directly, each 
of the layers would have to be processed first, i.e. using their 
own local storage and individual processing, before they could be 
blended with the layer behind. 

In the preferred embodiment, rather than blending all the 
layers from back to front, all of the layers that are to be 
processed (e.g. filtered) are layered together first, even if there 
is one or more layers behind them over which they should be 
blended, and the combined upper layers are then blended with the 
other layers that are not to be processed. For example, layers {1, 
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2 and 3} may be layers that are not to be processed, while layers 
{4, 5, 6, 7, and 8} may be layers that are to undergo processing, 
while all 8 layers are to be blended together, using {A(i)} values 
that are independent for every layer and pixel. The layers that 
5 are to be filtered, upper layers, may be the graphics windows. The 
lower layers may include the video window and passthrough video. 

In the preferred embodiment, all of the layers that are to be 
filtered (referred to as "upper" layers) are blended together from 
10 back to front using a partial blending operation. In an alternate 
embodiment, two or more of the upper layers may be blended together 
in parallel. The back-most of the upper layers is not in general 
the back-most layer of the entire operation. 

15 In the preferred embodiment, at each stage of the blending, an 

intermediate alpha value is maintained for later use for blending 
with the layers that are not to be filtered (referred to as the 
"lower" layers) . 

20 The formula that represents the preferred blending scheme is: 

R(i) = A(i) * P(i) + (1- A(i)) * P(i-l) 

and 

AR(i) = AR(i-l) * (1- A(i)) 

where R(i) represents the color value of the resulting blended 
25 pixel, P(i) represents the color value of the current pixel, A(i) 
represents the alpha value of the current pixel, P(i-l) represents 
the value at the location of the current pixel of the composition 
of all of the upper layers behind the current pixel, initially this 
represents black before any layers are blended, AR(i) is the alpha 
30 value resulting from each instance of this operation, and AR(i-l) 
represents the intermediate alpha value at the location of the 
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current pixel determined from all of the upper layers behind the 
current pixel, initially this represents transparency before any 
layers are blended. AR represents the alpha value that will 
subsequently be multiplied by the lower layers as indicated below, 
5 and so an AR value of 1 (assuming alpha ranges from 0 to 1) 
indicates that the current pixel is transparent and the lower 
layers will be fully visible when multiplied by 1. 

In other words, in the preferred embodiment, at each stage of 
10 blending the upper layers, the pixels of the current layer are 
blended using the current alpha value, and also an intermediate 
alpha value is calculated as the product (l-A(i)) * (AR(i-l)). The 
key differences between this and the direct evaluation of the 
conventional formula are: (1) the calculation of the product of the 
15 set of {(l-A(i))} for the upper layers, and (2) a virtual 
transparent black layer is used to initialize the process for 
blending the upper layers, since the lower layers that would 
normally be blended with the upper layers are not used at this 
point in this process. 

20 

The calculation of the product of the sets of { (l-A(i) } for 
the upper layers is implemented, in the preferred embodiment, by 
repeatedly calculating AR(i) = AR ( i-1 ) * ( 1-A ( i ) ) at each layer, such 
that when all layers {i} have been processed, the result is that AR 

25 = the product of all (l-A(i)) values for all upper layers. 

Alternatively in other embodiments, the composite alpha value for 
each pixel of blended graphics may be calculated directly as the 
product of all (1-alpha value of the corresponding pixel of the 
graphics image on each layer) ' s without generating an intermediate 

30 alpha at each stage. 
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To complete the blending process of the entire series of 
layers, including the upper and lower layers, once the upper layers 
have been blended together as described above, they may be 
processed as desired and then the result of this processing, a 
5 composite intermediate image, is blended with the lower layer or 
layers. In addition, the resulting alpha values preferably are 
also processed in essentially the same way as the image components. 
The lower layers can be blended in the conventional fashion, so at 
some point there can be a single image representing the lower 
10 layers. Therefore two images, one representing the upper layers 
and one representing the lower layers can be blended together. In 
this operation, the AR(n) value at each pixel that results from the 
blending of the upper layers and any subsequent processing is used 
to be multiplied with the composite lower layer. 

15 

Mathematically this latter operation is as follows: let L(u) 
be the composite upper layer resulting from the process described 
above and after any processing, let AR(u) be the composite alpha 
value of the upper layers resulting from the process above and 

20 after any processing, let L(l) be the composite lower layer that 
results from blending all lower layers in the conventional fashion 
and after any processing, and let Result be the final result of 
blending all the upper and lower layers, after any processing. 
Then, Result = L(u) + AR(u) * L(l). L(u) does not need to be 

25 multiplied by any additional alpha values, since all such 
multiplication operations were already performed at an earlier 
stage . 

In the preferred embodiment, a series of images makes up the 
30 upper layers. These are created by reading pixels from memory, as 
in a conventional graphics display device. Each pixel is converted 
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into a common format if it is not already in that format; in this 
example the YUV format is used. Each pixel also has an alpha value 
associated with it. The alpha values can come from a variety of 
sources, including (1) being part of the pixel value read from 
5 memory (2) an element in a color look-up table (CLUT) in cases 
where the pixel format uses a CLUT (3) calculated from the pixel 
color value, e.g. alpha as a function of Y, (4) calculated using a 
keying function, i.e. some pixel values are transparent (i.e. alpha 
= 0) and others are opaque (alpha = 1) based on a comparison of the 
10 pixel value with a set of reference values, (5) an alpha value may 
be associated with a region of the image as described externally, 
such as a rectangular region, described by the four corners of the 
rectangle, may have a single alpha value associated with it, or (6) 
some combination of these. 

15 

The upper layers are preferably composited in memory storage 
buffers called line buffers. Each line buffer preferably is sized 
to contain pixels of one scan line. Each line buffer has an 
element for each pixel on a line, and each pixel in the line buffer 

20 has elements for the color components, in this case Y, U and V, and 
one for the intermediate alpha value AR. Before compositing of 
each line begins, the appropriate line buffer is initialized to 
represent a transparent black having already been composited into 
the buffer; that is, the YUV value is set to the value that 

25 represents black (i.e. Y = 0, U = V - 128) and the alpha value AR 
is set to represent ( 1-t ransparent ) = (1-0) = 1. 

Each pixel of the current layer on the current line is 
combined with the value pre-existing in the line buffer using the 
30 formulas already described, i.e., 

R(i) = A(i) * P(i) + (1 - A(i)) * P(i-l) 
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and 

AR(i) = AR(i-l) * (1 - A(i)). 

In other words, the color value of the current pixel P(i) is 
5 multiplied by its alpha value A(i), and the pixel in the line 
buffer representing the same location on the line P(i-l) is read 
from the line buffer, multiplied by (l-A(i)), and added to the 
previous result, producing the resulting pixel value R(i). Also, 
the alpha value at the same location in the line buffer (AR(i-l)) 
10 is read from the buffer and multiplied by (l-A(i)), producing 
AR(i) . The results R(i) and AR(i) are then written back to the 
line buffer in the same location. 

When multiplying a YUV value by an alpha value between 0 and 
1, the offset nature of the U and V values should preferably be 
accounted for. In other words, U = V = 128 represents a lack of 
color and it is the value that should result from a YUV color value 
being multiplied by 0. This can be done in at least two ways. In 
one embodiment of the present invention, 128 is subtracted from the 
U and V values before multiplying by alpha, and then 128 is added 
to the result. In another embodiment, U and V values are directly 
multiplied by alpha, and it is ensured that at the end of the 
entire compositing process all of the coefficients multiplied by U 
and V sum to 1, so that the offset 128 value is not distorted 
significantly . 

Each of the layers in the group of upper layers is preferably 
composited into a line buffer starting with the back-most of the 
upper layers and progressing towards the front until the front-most 
30 of the upper layers has been composited into the line buffer. In 
this way, a single hardware block, i.e., the display engine, may be 
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used to implement the formula above for all of the upper layers. In 
this arrangement, the graphics compositor engine preferably 
operates at a clock frequency that is substantially higher than the 
pixel display rate. In one embodiment of the present invention, the 
5 graphics compositor engine operates at 81MHz while the pixel 
display rate is 13.5 MHz. 

This process repeats for all of the lines in the entire image, 
starting at the top scan line and progressing to the bottom. Once 

10 the compositing of each scan line into a line buffer has been 
completed, the scan line becomes available for use in processing 
such as filtering or scaling. Such processing may be performed 
while subsequent scan lines are being composited into other line 
buffers. Various processing operations may be selected such as 

15 anti-flutter filtering and vertical scaling. 

In alternative embodiments more than one graphics layer may be 
composited simultaneously, and in some such embodiments it is not 
necessary to use line buffers as part of the compositing process. 
20 If all upper layers are composited simultaneously, the combination 
of all upper layers can be available immediately without the use of 
intermediate storage . 

Referring to FIG. 29, a flow diagram of a process of blending 
25 graphics windows is illustrated. The system preferably resets in 
step 920. In step 922, the system preferably checks for a vertical 
sync (VSYNC) . If a VSYNC has been received, the system in step 924 
preferably loads a line from the bottom most graphics window into 
a graphics line buffer. Then the system in step 926 preferably 
30 blends a line from the next graphics window into the line buffer. 
Then the system in step 928 preferably determines if the last 
graphics window visible on a current display line has been blended. 
If the last graphics window has not been blended, the system 
continues on with the blending process in step 926. 
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If the last window of the current display line has been 
reached, the system preferably checks in step 930 to determine if 
the last graphics line of a current display field has been blended. 
5 If the last graphics line has been blended, the system awaits 
another VSYNC in step 922. If the last graphics line has not been 
blended, the system goes to the next display line in step 932 and 
repeats the blending process. 

10 Referring to FIG. 30, a flow diagram of a process of receiving 

blended graphics 950, a video window 952 and a passthrough video 
954 and blending them. A background color preferably is also 
blended in one embodiment of the present invention. As step 956 
indicates, the video compositor preferably displays each pixel as 

15 they are composited without saving pixels to a frame buffer or 
other memory. 

When the video signals and graphics data are blended in the 
video compositor, the system in step 958 preferably displays the 

20 passthrough video 954 outside the active window area first. There 
are 525 scan lines in each frame and 858 pixels in each scan line 
of NTSC standard television signals, when a sample rate of 13.5MHz 
is used, per ITU-R Bt.601. An active window area of the NTSC 
standard television is inside an NTSC frame. There are 625 scan 

25 lines per frame and 864 pixels in each scan line of PAL standard 
television, when using the ITU-R Bt.601 standard sample rate of 
13.5MHz. An active window area of the PAL standard television is 
inside a PAL frame. 

30 Within the active window area, the system in step 960 

preferably blends the background color first. On top of the 
background color, the system in step 962 preferably blends the 
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portion of the passthrough video that falls within the active 
window area. On top of the passthrough window, the system in step 
964 preferably blends the video window. Finally, the system in step 
968 blends the graphics window on top of the composited video 
5 window and outputs composited video 970 for display. 

Interlaced displays, such as televisions, have an inherent 
tendency to display an apparent vertical motion at the horizontal 
edges of displayed objects, with horizontal lines, and on other 
10 points on the display where there is a sharp contrast gradient 
along the vertical axis. This apparent vertical motion is 
variously referred to as flutter, flicker, or judder. 

While some image elements can be designed specifically for 
15 display on interlaced TVs or filtered before they are displayed, 
when multiple such image objects are combined onto one screen, 
there are still visible flutter artifacts at the horizontal top and 
bottom edges of these objects. While it is also possible to 
include filters in hardware to minimize visible flutter of the 
20 display, such filters are costly in that they require higher memory 
bandwidth from the display memory, since both even and odd fields 
should preferably be read from memory for every display field, and 
they tend to require additional logic and memory on-chip. 

25 One embodiment of the present invention includes a method of 

reducing interlace flutter via automatic blending. This method has 
been designed for use in graphics displays device that composites 
visible objects directly onto the screen; for example, the device 
may use windows, window descriptors and window descriptor lists, or 

30 similar mechanisms. The top and bottom edges (first and last scan 
lines) of each object (or window) are displayed such that the alpha 
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blend value (alpha blend factor) of these edges is adjusted to be 
one-half of what it would be if these same lines were not the top 
and bottom lines of the window. 

5 For example, a window may constitute a rectangular shape, and 

the window may be opaque, i.e. it's alpha blend factor is 1, on a 
scale of 0 to 1. All lines on this window except the first and 
last are opaque when the window is rendered. The top and bottom 
lines are adjusted so that, in this case, the alpha blend value 

10 becomes 0.5, thereby causing these lines to be mixed 50% with the 
images that are behind them. This function occurs automatically in 
the preferred implementation. Since in the preferred 
implementation, windows are rectangular objects that are rendered 
directly onto the screen, the locations of the top and bottom lines 

15 of every window are already known. 

In one embodiment, the function of dividing the alpha blend 
values for the top and bottom lines by two is implemented only for 
the top fields of the interlaced display. In another embodiment, 
20 the function of dividing the alpha blend values for the top and 
bottom lines by two is implemented only for the bottom fields of 
the interlaced display. 

In the preferred embodiment, there exists also the ability to 
25 alpha blend each window with the windows behind it, and this alpha 
value can be adjusted for every pixel, and therefore for every scan 
line. These characteristics of the application design are used 
advantageously, as the flutter reduction effect is implemented by 
controlling the alpha blend function using information that is 
30 readily available from the window control logic. 
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In a specific illustrative example, the window is solid opaque 
white, and the image behind it is solid opaque black. In the 
absence of the disclosed method, at the top and bottom edges of the 
window there would be a sharp contrast between black and white, and 
5 when displayed on an interlaced TV, significant flutter would be 
visible. Using the disclosed method, the top and bottom lines are 
blended 50% with the background, resulting in a color that is 
halfway between black and white, or gray. When displayed on an 
interlaced TV, the apparent visual location of the top and bottom 
10 edges of the object is constant, and flutter is not apparent. The 
same effect applies equally well for other image examples. 

The method of reducing interlace flutter of this embodiment 
does not require any increase in memory bandwidth, as the alternate 
15 field (the one not currently being displayed) is not read from 
memory, and there is no need for vertical filtering, which would 
have required logic and on-chip memory. 

The same function can alternatively be implemented in 
20 different graphics hardware designs. For example in designs using 
a frame buffer (conventional design), graphic objects can be 
composited into the frame buffer with an alpha blend value that is 
adjusted to one-half of its normal value at the top and bottom 
edges of each object. Such blending can be performed in software or 
25 in a blitter that has a blending capability. 

XI. Anti-Flutter Filtering / Vertical Scaling 

In the preferred embodiment, the vertical filtering and anti- 
30 flutter filtering are performed on blended graphics by one graphics 
filter. One function of the graphics filter is low pass filtering 
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in the vertical dimension. The low pass filtering may be performed 
in order to minimize the "flutter" effect inherent in interlaced 
displays such as televisions. The vertical downscaling or 
upscaling operation may be performed in order to change the pixel 
5 aspect ratio from the square pixels that are normal for computer, 
Internet and World Wide Web content into any of the various oblong 
aspect ratios that are standard for televisions as specified in 
ITU-R 601B. In order to be able to perform vertical scaling of the 
upper layers the system preferably includes seven line buffers. 
10 This allows for four line buffers to be used for filtering and 
scaling, two are available for progressing by one or two lines at 
the end of every line, and one for the current compositing 
operation . 

15 When scaling or filtering are performed, the alpha values in 

the line buffers are filtered or scaled in the same way as the YUV 
values, ensuring that the resulting alpha values correctly 
represent the desired alpha values at the proper location. Either 
or both of these operations, or neither, or other processing, may 

20 be performed on the contents of the line buffers. 

Once the optional processing of the contents of the line 
buffers has been completed, the result is the completed set of 
upper layers with the associated alpha value (product of (l-A(i)). 

25 These results are used directly for compositing the upper layers 
with the lower layers, using the formula: Result = L(u) - AR(u) * 
L(l) as explained in detail in reference to blending of graphics 
and video. If the lower layers require any processing independent 
of processing required for the upper layers or for the resulting 

30 image, the lower layers are processed before being combined with 
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the upper layers; however in one embodiment of the present 
invention, no such processing is required. 

Each of the operations described above is preferably 
5 implemented digitally using conventional ASIC technology. As part 
of the normal ASIC technology the logical operations are segmented 
into pipeline stages, which may require temporary storage of logic 
values from one clock cycle to the next. The choice of how many 
pipeline stages are used in each of the operations described above 

10 is dependent on the specific ASIC technology used, the clock speed 
chosen, the design tools used, and the preference of the designer, 
and may vary without loss of generality. In the preferred 
embodiment the line buffers are implemented as dual port memories 
allowing one read and one write cycle to occur simultaneously, 

15 facilitating the read and write operations described above while 
maintaining a clock frequency of 81MHz. In this embodiment the 
compositing function is divided into multiple pipeline stages, and 
therefore the address being read from the memory is different from 
the address being written to the same memory during the same clock 

20 cycle. 



Each of the arithmetic operations described above in the 
preferred embodiment use 8 bit accuracy for each operand; this is 
generally sufficient for providing an accurate final result. 
25 Products are rounded to 8 bits before the result is used in 
subsequent additions . 



Referring to FIG. 31, a block diagram illustrates an 
interaction between the line buffers 504 and a graphics filter 172. 
30 The line buffers comprises a set of line buffers 1-7 506a-g. The 
line buffers are controlled by a graphics line buffer controller 
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over a line buffer control interface 502. In one embodiment of the 
present invention, the graphics filter is a four-tap polyphase 
filter, so that four lines of graphics data 516a-d are provided to 
the graphics filter at a time. The graphics filter 172 sends a 
5 line buffer release signal 516e to the line buffers to notify that 
one to three line buffers are available for compositing additional 
graphics display lines. 

In another embodiment, line buffers are not used, but rather 
10 all of the upper layers are composited concurrently. In this case, 
there is one graphics blender for each of the upper layers active 
at any one pixel, and the clock rate of the graphics blender may be 
approximately equal to the pixel display rate. The clock rate of 
the graphics blenders may be somewhat slower or faster, if FIFO 
15 buffers are used at the output of the graphics blenders. 

The mathematical formulas implemented are the same as in the 
first embodiment described. The major difference is that instead 
of performing the compositing function iteratively by reading and 
20 writing a line buffer, all layers are composited concurrently and 
the result of the series of compositor blocks is immediately 
available for processing, if required, and for blending with the 
lower layers, and line buffers are not used for purposes of 
compositing . 

25 

Line buffers may still be needed in order to implement 
vertical filtering or vertical scaling, as those operations 
typically require more than one line of the group of upper layers 
to be available simultaneously, although fewer line buffers are 
30 generally required here than in the preferred embodiment. Using 
multiple graphics blenders operating at approximately the pixel 
rate simplifies the implementation in applications where the pixel 
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rate is relatively fast for the ASIC technology used, for example 
in HDTV video and graphics systems where the pixel rate is 74.25 
MHz . 

5 XII. Unified Memory Architecture / Real Time Scheduling 

Recently, improvements to memory fabrication technologies have 
resulted in denser memory chips. However memory chip bandwidth has 
not been increasing as rapidly. The bandwidth of a memory chip is 

10 a measure of how fast contents of the memory chip can be accessed 
for reading or writing. As a result of increased memory density 
without necessarily a commensurate increase in bandwidth, in many 
conventional system designs multiple memory devices are used for 
different functions, and memory space in some memory modules may go 

15 unused or is wasted. In the preferred embodiment, a unified memory 
architecture is used. In the unified memory architecture, all the 
tasks (also referred to as "clients") , including CPU, display 
engine and 10 devices, share the same memory. 

20 The unified memory architecture preferably includes a memory 

that is shared by a plurality of devices, and a memory request 
arbiter coupled to the memory, wherein the memory request arbiter 
performs real time scheduling of memory requests from different 
devices having different priorities. The unified memory system 

25 assures real time scheduling of tasks, some of which do not 
inherently have pre-determined periodic behavior and provides 
access to memory by requesters that are sensitive to latency and do 
not have determinable periodic behavior. 

30 In an alternate embodiment, two memory controllers are used in 

a dual memory controller system. The memory controllers may be 16- 
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bit memory controllers or 32-bit memory controllers. Each memory 
controller can support different configuration of SDRAM device 
types and banks, or other forms of memory besides SDRAM. A first 
memory space addressed by a first memory controller is preferably 
5 adjacent and contiguous to a second memory space addressed by a 
second memory controller so that software applications view the 
first and second memory spaces as one continuous memory space. The 
first and the second memory controllers may be accessed 
concurrently by different clients. The software applications may 
10 be optimized to improve performance. 

For example, a graphics memory may be allocated through the 
first memory controller while a CPU memory is allocated through the 
second memory controller. While a display engine is accessing the 

15 first memory controller, a CPU may access the second memory 
controller at the same time. Therefore, a memory access latency of 
the CPU is not adversely affected in this instance by memory being 
accessed by the display engine and vice versa. In this example, the 
CPU may also access the first memory controller at approximately 

20 the same time that the display engine is accessing the first memory 
controller, and the display controller can access memory from the 
second memory controller, thereby allowing sharing of memory across 
different functions, and avoiding many copy operations that may 
otherwise be required in conventional designs. 

25 

Referring to FIG. 32, a dual memory controller system services 
memory requests generated by a display engine 1118, a CPU 1120, a 
graphics accelerator 1124 and an input/output module 1126 are 
provided to a memory select block 1100. The memory select block 
30 1100 preferably routes the memory requests to a first arbiter 1102 
or to a second arbiter 1106 based on the address of the requested 
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memory. The first arbiter 1102 sends memory requests to a first 
memory controller 1104 while the second arbiter 1106 sends memory 
requests to a second memory controller 1108. The design of 
arbiters for handling requests from tasks with different priorities 
5 is well known in the art. 

The first memory controller preferably sends address and 
control signals to a first external SDRAM and receives a first data 
from the first external SDRAM. The second memory controller 
10 preferably sends address and control signals to a second external 
SDRAM and receives a second data from the second external SDRAM. 

The first and second memory controllers preferably provide first 
and second data received, respectively, from the first and second 
external SDRAMs to a device that requested the received data. 

15 

The first and second data from the first and second memory 
controllers are preferably multiplexed, respectively, by a first 
multiplexer 1110 at an input of the display engine, by a second 
multiplexer 1112 at an input of the CPU, by a third multiplexer 
20 1114 at an input of the graphics accelerator and by a fourth 
multiplexer 1116 at an input of the I/O module. The multiplexers 
provide either the first or the second data, as selected by memory 
select signals provided by the memory select block, to a 
corresponding device that has requested memory. 

25 

An arbiter preferably uses an improved form of real time 
scheduling to meet real-time latency requirements while improving 
performance for latency-sensitive tasks. First and second arbiters 
may be used with the flexible real time scheduling. The real time 
30 scheduling is preferably implemented on both the first arbiter and 
the second arbiter independently. 
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When using a unified memory, memory latencies caused by 
competing memory requests by different tasks should preferably be 
addressed. In the preferred embodiment, a real-time scheduling and 
arbitration scheme for unified memory is implemented, such that all 
5 tasks that use the unified memory meet their real-time 
requirements. With this innovative use of the unified memory 
architecture and real-time scheduling, a single unified memory is 
provided to the CPU and other devices of the graphics display 
system without compromising quality of graphics or other operations 
10 and while simultaneously minimizing the latency experienced by the 
CPU. 

The methodology used preferably implements real-time 
scheduling using Rate Monotonic Scheduling ( "RMS" ) . It is a 

15 mathematical approach that allows the construction of provably 
correct schedules of arbitrary numbers of real-time tasks with 
arbitrary periods for each of the tasks. This methodology provides 
for a straight forward means for proof by simulation of the worst 
case scenario, and this simulation is simple enough that it can be 

20 done by hand. RMS, as normally applied, makes a number of 
simplifying assumptions in the creation of a priority list. 

In the normal RMS assumptions, all tasks are assumed to have 
constant periods, such that a request for service is made by the 

25 task with stated period, and all tasks have a latency tolerance 
that equals that task's period. Latency tolerance is defined as 
the maximum amount of time that can pass from the moment the task 
requests service until that task' s request has been completely 
satisfied. During implementation of one embodiment of the present 

30 invention, the above assumptions have been modified, as described 
below. 

In the RMS method, all tasks are generally listed along with 
their periods. They are then ordered by period, from the shortest 
to the longest, and priorities are assigned in that order. Multiple 
35 tasks with identical periods can be in any relative order. In 
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other words, the relative order amongst them can be decided by, for 
example, flipping a coin. 

Proof of correctness, i.e. the guarantee that all tasks meet 
5 their deadlines, is constructed by analyzing the behavior of the 
system when all tasks request service at exactly the same time; 
this time is called the "critical instant". This is the worst case 
scenario, which may not occur in even a very large set of 
simulations of normal operation, or perhaps it may never occur in 

10 normal operation, however it is presumed to be possible. As each 
task is serviced, it uses the shared resource, memory clock cycles 
in the present invention, in the degree stated by that task. If all 
tasks meet their deadlines, the system is guaranteed to meet all 
tasks' deadlines under all conditions, since the critical instant 

15 analysis simulates the worst case. 

When the lowest priority real-time task meets its deadline, 
without any higher priority tasks missing their deadlines, then all 
tasks are proven to meet their deadlines. As soon as any task in 
20 this simulation fails to meet its deadline, the test has failed and 
the task set cannot be guaranteed, and therefore the design should 
preferably be changed in order to guarantee proper operation under 
worst case conditions. 

25 In the RMS methodology, real-time tasks are assumed to have 

periodic requests, and the period and the latency tolerance are 
assumed to have the same value. Since the requests may not be in 
fact periodic, it is clearer to speak in terms of "minimum 
interval" rather than period. That is, any task is assumed to be 

30 guaranteed not to make two consecutive requests with an interval 
between them that is any shorter than the minimum interval. 

The deadline, or the latency tolerance, is the maximum amount 
of time that may pass between the moment a task makes a request for 
35 service and the time that the service is completed, without 
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impairing the function of the task. For example, in a data path 
with a constant rate source (or sink) , a FIFO, and memory access 
from the FIFO, the request may occur as soon as there is enough 
data in the FIFO that if service is granted immediately the FIFO 
5 does not underflow (or overflow in case of a read operation 
supporting a data sink) . If service is not completed before the 
FIFO overflows (or underflows in the case of a data sink) the task 
is impaired. 

10 In the RMS methodology, those tasks that do not have specified 

real-time constraints are preferably grouped together and served 
with a single master task called the "sporadic server", which 
itself has the lowest priority in the system. Arbitration within 
the set of tasks served by the sporadic server is not addressed by 

15 the RMS methodology, since it is not a real-time matter. Thus, all 
non-real-time tasks are served whenever there is resource 
available, however the latency of serving any one of them is not 
guaranteed . 

20 To implement real-time scheduling based on the RMS 

methodology, first, all of the tasks or clients that need to access 
memory are preferably listed, not necessarily in any particular 
order. Next, the period of each of the tasks is preferably 
determined. For those with specific bandwidth requirements (in 

25 bytes per second of memory access), the period is preferably 
calculated from the bandwidth and the burst size. If the deadline 
is different from the period for any given task, that is listed as 
well. The resource requirement when a task is serviced is listed 
along with the task. In this case, the resource requirement is the 

30 number of memory clock cycles required to service the memory access 
request. The tasks are sorted in order of increasing period, and 
the result is the set of priorities, from highest to lowest. If 
there are multiple tasks with the same period, they can be given 
different, adjacent priorities in any random relative order within 

35 the group; or they can be grouped together and served with a single 



116 



WO 00/28518 



PCT/US99/26484 



priority, with round-robin arbitration between those tasks at the 
same priority. 

In practice, the tasks sharing the unified memory do not all 
5 have true periodic behavior. In one embodiment of the present 
invention, a block out timer, associated with a task that does not 
normally have a period, is used in order to force a bounded minimum 
interval, similar to a period, on that task. For example a block 
out timer associated with the CPU has been implemented in this 

10 embodiment. If left uncontrolled, the CPU can occupy all available 
memory cycles, for example by causing a never-ending stream of 
cache misses and memory requests. At the same time, CPU 
performance is determined largely by "average latency of memory 
access", and so the CPU performance would be less than optimal if 

15 all CPU memory accessed were consigned to a sporadic server, i.e., 
at the lowest priority. 

In this embodiment, the CPU task has been converted into two 
logical tasks. A first CPU task has a very high priority for low 

20 latency, and it also has a block out timer associated with it such 
that once a request by the CPU is made, it cannot submit a request 
again until the block out timer has timed out. In this embodiment, 
the CPU task has the top priority. In other embodiments, the CPU 
task may have a very high priority but not the top priority. The 

25 timer period has been made programmable for system tuning, in order 
to accommodate different system configurations with different 
memory widths or other options. 

In one embodiment of the present invention, the block out 
30 timer is started when the CPU makes a high priority request. In 
another embodiment, the block out timer is started when the high 
priority request by the CPU is serviced. In other embodiments, the 
block out timer may be started at any time in the interval between 
the time the high priority request is made and the time the high 
35 priority request is serviced. 
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A second CPU task is preferably serviced by a sporadic server 
in a round-robin manner. Therefore if the CPU makes a long string 
of memory requests, the first one is served as a high priority 
5 task, and subsequent requests are served by the low priority 
sporadic server whenever none of the real-time tasks have requests 
pending, until the CPU block out timer times out. In one embodiment 
of the present invention, the graphics accelerator and the display 
engine are also capable of requesting more memory cycles than are 
10 available, and so they too use similar block out timer. 

For example, the CPU read and write functions are grouped 
together and treated as two tasks. A first task has a theoretical 
latency bound of 0 and a period that is programmable via a block 
15 out timer, as described above. A second task is considered to have 
no period and no deadline, and it is grouped into the set of tasks 
served by the sporadic server via a round robin at the lowest 
priority. The CPU uses a programmable block out timer between high 
priority requests in this embodiment. 

20 

For another example, a graphics display task is considered to have 
a constant bandwidth of 27 MB/s, i.e., 16 bits per pixel at 
13.5MHz. However, the graphics bandwidth in one embodiment of the 
present invention can vary widely from much less than 27 MB/s to a 

25 much greater figure, but 27 MB/s is a reasonable figure for 
assuring support of a range of applications. For example, in one 
embodiment of the present invention, the graphics display task 
utilizes a block out timer that enforces a period of 2.37 |is 
between high priority requests, while additional requests are 

30 serviced on a best-effort basis by the sporadic server in a low 
priority round robin manner. 

Referring to FIG. 33, a block diagram illustrates an 
implementation of a real-time scheduling using an RMS methodology. 
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A CPU service request 1138 is preferably coupled to an input of a 
block out timer 1130 and a sporadic server 1136. An output of the 
block out timer 1130 is preferably coupled to an arbiter 1132 as a 
high priority service request. Tasks 1-5 1134a-e may also be 
5 coupled to the arbiter as inputs. An output of the arbiter is a 
request for service of a task that has the highest priority among 
all tasks that have a pending memory request. 

In FIG. 33, only the CPU service request 1138 is coupled to a 
block out timer. In other embodiments, service requests from other 
tasks may be coupled to their respective block out timers. The 
block out timers are used to enforce a minimum interval between two 
successive accesses by any high priority task that is non-periodic 
but may require expedited servicing. Two or more such high 
priority tasks may be coupled to their respective block out timers 
in one embodiment of the present invention. Devices that are 
coupled to their respective block out timers as high priority tasks 
may include a graphics accelerator, a display engine, and other 
devices . 

In addition to the CPU request 1138, low priority tasks 1140a- 
d may be coupled to the sporadic server 1136. In the sporadic 
server, these low priority tasks are handled in a round robin 
manner. The sporadic server sends a memory request 1142 to the 
arbiter for the next low priority task to be serviced. 

Referring to FIG. 34, a timing diagram illustrates CPU service 
requests and services in case of a continuous CPU request 114 6. In 
practice, the CPU request is generally not continuous, but FIG. 34 
30 has been provided for illustrative purposes. In the example 
represented in FIG. 34, a block out timer 1148 is started upon a 
high priority service request 1149 by the CPU. At time t 0 , the CPU 
starts making the continuous service request 1146, and a high 
priority service request 1149 is first made provided that the block 
35 out timer 1148 is not running at time to- When the high priority 
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service request is made, the block out timer 1148 is started. - 
Between time t 0 and time ti, the memory controller finishes 
servicing a memory request from another task. The CPU is first 
serviced at time ti. In the preferred embodiment, the duration of 
5 the block out timer is programmable. For example, the duration of 
the block out timer may be programmed to be 3 (as . 

Any additional high priority CPU request 1149 is blocked out 
until the block out timer times out at time t 2 . Instead, the CPU 

10 low priority request 1150 is handled by a sporadic server in a 
round robin manner between time t 0 and time t 2 . The low priority 
request 1150 is active as long as the CPU service request is 
active. Since the CPU service request 1146 is continuous, another 
high priority service request 1149 is made by the CPU and the block 

15 out timer is started again as soon as the block out timer times out 
at time t 2 . The high priority service request made by the CPU at 
time t2 is serviced at time t 3 when the memory controller finishes 
servicing another task. Until the block out timer times out at 
time t 4 , the CPU low priority request 1150 is handled by the 

20 sporadic server while the CPU high priority request 114 9 is blocked 
out . 

Another high priority service request is made and the block 
out timer 1148 is started again when the block out timer 1148 times 

25 out at time t 4 . At time ts, the high priority service request 1149 
made by the CPU at time t 4 is serviced. The block out timer does 
not time out until time t 7 . However, the block out timer is not in 
the path of the CPU low priority service request and, therefore, 
does not block out the CPU low priority service request. Thus, 

30 while the block out timer is still running, a low priority service 
request made by the CPU is handled by the sporadic server, and 
serviced at time t 6 . 
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When the block out timer 1148 times out at time t 7 , it is 
started again and yet another high priority service request is made 
by the CPU, since the CPU service request is continuous. The high 
priority service request 1149 made by the CPU at time t 7 is 
5 serviced at time t 8 . When the block out timer times out at time t 9/ 
the high priority service request is once again made by the CPU and 
the block out timer is started again. 

The schedule that results from the task set and priorities 
10 above is verified by simulating the system performance starting 
from the "critical instant", when all tasks request service at the 
same time and a previously started low priority task is already 
underway. The system is proven to meet all the real-time deadlines 
if all of the tasks with real-time deadlines meet their deadlines. 
15 Of course, in order to perform this simulation accurately, all 
tasks make new requests at every repetition of their periods, 
whether or not previous requests have been satisfied. 

Referring to FIG. 35, a timing diagram illustrates an example 
20 of a critical instant analysis. At time t 0 , a task 1 1156, a task 
2 1158, a task 3 1160 and a task 4 1162 request service at the same 
time. Further, at time t 0 , a low priority task 1154 is being 
serviced. Therefore, the highest priority task, the task 1, cannot 
be serviced until servicing of the low priority task has been 
25 completed. 
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For example, referring to FIG. 36, a flow diagram illustrates 
a process of servicing memory requests with different priorities, 
from the highest to the lowest. The system in step 1170 makes a 
CPU read request with the highest priority. Since a block out 
5 timer is used with the CPU read request in this example, the block 
out timer is started upon making the highest priority CPU read 
request. Then the system in step 1172 makes a graphics read 
request. A block out timer is also used with the graphics read 
request, and the block out timer is started upon making the 
10 graphics read request. 

A video window read request in step 1174 and a video capture 
write request in step 1176 have equal priorities. Tnerefore, the 
video window read request and the video capture write request are 
15 placed in a round robin arbitration for two tasks (clients) . The 
system in step 1178 and step 1180 services a refresh request and a 
audio read request, respectively. 

While respective block out timers for the CPU read request and 
20 the graphics read request are active, the system places the CPU 
read request and the graphics read request in a round robin 
arbitration for five tasks (clients), respectively, in step 1182 
and step 1186. The system in steps 1184, 1188 and 1190 places 
other lowest priority tasks such as a graphics accelerator 
25 read/write request, a DMA read/write request and a CPU write 
request, respectively, in this round robin arbitration with five 
clients . 

XIII. Graphics Accelerator 

30 

Displaying of graphics generally requires a large amount of 
processing. If all processing of graphics is performed by a CPU, 
the processing requirements may unduly burden the CPU since the CPU 
generally also performs many other tasks. Therefore, many systems 



122 



WO 00/28518 



PCT/US99/26484 



that perform graphics processing use a dedicated processor, which 
is typically referred to as a graphics accelerator. 

The system according to the present invention may employ a 
5 graphics accelerator that includes memory for graphics data, the 
graphics data including pixels, and a coprocessor for performing 
vector type operations on a plurality of components of one pixel of 
the graphics data. 

10 The preferred embodiment of the graphics display system uses 

a graphics accelerator that is optimized for performing real-time 
3D and 2D effects on graphics and video surfaces. The graphics 
accelerator preferably incorporates specialized graphics vector 
arithmetic functions for maximum performance with video and real- 

15 time graphics. The graphics accelerator performs a range of 
essential graphics and video operations with performance comparable 
to hardwired approaches, yet it is programmable so that it can meet 
new and evolving application requirements with firmware downloads 
in the field. The graphics accelerator is preferably capable of 3D 

20 effects such as real-time video warping and flipping, texture 
mapping, and Gouraud and Phong polygon shading, as well as 2D and 
image effects such as blending, scaling, blitting and filling. The 
graphics accelerator and its caches are preferably completely 
contained in an integrated circuit chip. 

25 

The graphics accelerator of the present invention is 
preferably based on a conventional RISC-type microprocessor 
architecture. The graphics accelerator preferably also includes 
additional features and some special instructions in the 
30 instruction set. In the preferred embodiment, the graphics 
accelerator is based on a MIPS R3000 class processor. In other 
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embodiments, the graphics accelerator may be based on almost any 
other type of processors. 

Referring to FIG. 37, a graphics accelerator 64 receives 
5 commands from a CPU 22 and receives graphics data from main memory 
28 through a memory controller 54. The graphics accelerator 
preferably includes a coprocessor (vector coprocessor) 1300 that 
performs vector type operations on pixels. In vector type 
operations, the R, G, and B components, or the Y, U and V 

10 components, of a pixel are processed in parallel as the three 
elements of a "vector". In alternate embodiments, the graphics 
accelerator may not include the vector coprocessor, and the vector 
coprocessor may be coupled to the graphics accelerator instead. 
The vector coprocessor 1300 obtains pixels (3-tuple vectors) via a 

15 specialized LOAD instruction. 

The LOAD instruction preferably extracts bits from a 32-bit 
word in memory that contains the required bits. The LOAD 
instruction also preferably packages and converts the bits into the 

20 input vector format of the coprocessor. The vector coprocessor 
1300 writes pixels (3-tuple vectors) to memory via a specialized 
STORE instruction. The STORE instruction preferably extracts the 
required bits from the accumulator (output) register of the 
coprocessor, converts them if required, and packs them into a 32- 

25 bit word in memory in a format suitable for other uses within the 
IC, as explained below. 

Formats of the 32-bit word in memory preferably include an 
RGB16 format and a YUV format. When the pixels are formatted in 
30 RGB16 format, R has 5 bits, G has 6 bits, and B has 5 bits. Thus, 
there are 16 bits in each RGB 16 pixel and there are two RGB 16 half- 
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words in every 32-bit word in memory. The two RGB16 half-words are 
selected, respectively, via VectorLoadRGB16Lef t instruction and 
VectorLoadRGB16Right instruction. The 5 or 6 bit elements are 
expanded through zero expansion into 8 bit components when loaded 
5 into the coprocessor input register 1308. 

The YUV format preferably includes YUV 4:2:2 format, which has 
four bytes representing two pixels packed into every 32-bit word in 
memory. The U and V elements preferably are shared between the two 

10 pixels. A typical packing format used to load two pixels having 
YUV 4:2:2 format into a 32-bit memory is YUYV, where each of first 
and second Y's, U and V has eight bits. The left pixel is 
preferably comprised of the first Y plus the U and V, and the right 
pixel is preferably comprised of the second Y plus the U and V. 

15 Special LOAD instructions, LoadYUVLeft and LoadYUVRight , are 
preferably used to extract the YUV values for the left pixel and 
the right pixel, respectively, and put them in the coprocessor 
input register 1308. 

20 Special STORE instructions, StoreVectorAccumulatorRGBl 6 , 

StoreVectorAccumulatorRGB2 4 , StoreVectorAccumulatorYUVLef t , and 
StoreVectorAccumulatorYUVRight , preferably convert the contents of 
the accumulator, otherwise referred to as the output register of 
the coprocessor, into a chosen format for storage in memory. In the 

25 case of StoreVectorAccumulatorRGBl 6 , the three components (R, G, 
and B) in the accumulator typically have 8, 10 or more significant 
bits each; these are rounded or dithered to create R, G, and B 
values with 5, 6, and 5 bits respectively, and packed into a 16 bit 
value. This 16 bit value is stored in memory, selecting either the 

30 appropriate 16 bit half word in memory via the store address. 
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In the case of StoreVectorAccumulatorRGB2 4 , the R, G, and B 
components in the accumulator are rounded or dithered to create 8 
bit values for each of the R, G, and B components, and these are 
packed into a 24 bit value. The 24 bit RGB value is written into 
memory at the memory address indicated via the store address. In 
the cases of StoreVectorAccumulatorYUVLef t and 

StoreVectorAccumulatorYUVRight , the Y, U and V components in the 
accumulator are dithered or rounded to create 8 bit values for each 
of the components. 

In the preferred embodiment, the StoreVectorAccumulatorYUVLef t 
instruction writes the Y, U and V values to the locations in the 
addressed memory word corresponding to the left YUV pixel, i.e. the 
word is arranged as YUYV, and the first Y value and the U and V 
values are over-written. In the preferred embodiment, the 
StoreVectorAccumulatorYUVRight instruction writes the Y value to 
the memory location corresponding to the Y component of the right 
YUV pixel, i.e. the second Y value in the preceding example. In 
other embodiments the U and V values may be combined with the U and 
V values already in memory creating a weighted sum of the existing 
and stored values and storing the result. 

The coprocessor instruction set preferably also includes a 
GreaterThanOREqualTo (GE) instruction. The GE instruction performs 
a greater-than-or-equal-to comparison between each element of a 
pair of 3-element vectors. Each element in each of the 3-element 
vectors has a size of one byte. The results of all three 
comparisons, one bit per each result, are placed in a result 
register 1310, which may subsequently be used for a single 
conditional branch operation. This saves a lot of instructions 
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(clock cycles) when performing comparisons between all the elements 
of two pixels. 

The graphics accelerator preferably includes a data SRAM 1302, 
also called a scratch pad memory, and not a conventional data 
cache. In other embodiments, the graphics accelerator may not 
include the data SRAM, and the data SRAM may be coupled to the 
graphics accelerator instead. The data SRAM 1302 is similar to a 
cache that is managed in software. The graphics accelerator 
preferably also includes a DMA engine 1304 with queued commands. 

In other embodiments, the graphics accelerator may not include the 
DMA engine, and the DMA engine may be coupled to the graphics 
accelerator instead. The DMA engine 1304 is associated with the 
data SRAM 1302 and preferably moves data between the data SRAM 1302 
and main memory 28 at the same time the graphics accelerator 64 is 
using the data SRAM 1302 for its load and store operations. In the 
preferred embodiment, the main memory 28 is the unified memory that 
is shared by the graphics display system, the CPU 22, and other 
peripherals . 

The DMA engine 1304 preferably transfers data between the 
memory 28 and the data SDRAM 1302 to carry out load and store 
instructions. In other embodiments, the DMA engine 1304 may 
transfer data between the memory 28 and other components of the 
graphics accelerator without using the data SRAM 1302. Using data 
SRAM, however, generally results in faster loading and storing 
operations . 

The DMA engine 1304 preferably has a queue 1306 to hold 
multiple DMA commands, which are executed sequentially in the order 
they are received. In the preferred embodiment, the queue 1306 is 
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four instructions deep. This may be valuable because the software 
(firmware) may be structured so that the loop above the inner loop 
may instruct the DMA engine 1304 to perform a series of transfers, 
e.g. to get two sets of operands and write one set of results back, 
5 and then the inner loop may execute for a while; when the inner 
loop is done, the graphics accelerator 64 may check the command 
queue 1306 in the DMA engine 1304 to see if all of the DMA commands 
have been completed. The queue includes a mechanism that allows 
the graphics accelerator to determine when all the DMA commands 

10 have been completed. If all of the DMA commands have been 
completed, the graphics accelerator 64 preferably immediately 
proceeds to do more work, such as commanding additional DMA 
operations to be performed and to do processing on the new 
operands. If not, the graphics accelerator 64 preferably waits for 

15 the completion of DMA commands or perform some other tasks for a 
while . 

Typically, the graphics accelerator 64 is working on operands 
and producing outputs for one set of pixels, while the DMA engine 

20 1304 is bringing in operands for the next (future) set of pixel 
operations, and also the DMA engine 1304 is writing back to memory 
the results from the previous set of pixel operations. In this 
way, the graphics accelerator 64 does not ever have to wait for DMA 
transfers (if the code is designed well) , unlike a conventional 

25 data cache, wherein the conventional data cache gets new operands 
only when there is a cache miss, and it writes back results only 
when either the cache writes it back automatically because it needs 
the cache line for new operands or when there is an explicit cache 
line flush operation performed. Therefore, the graphics 

30 accelerator 64 of the present invention preferably reduces or 
eliminates period of waiting for data, unlike conventional graphics 
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accelerators which may spend a large fraction of their time waiting 
for data transfer operations between the cache and main memory. 

Although this invention has been described in certain specific 
embodiments , many additional modifications and variations would be 
apparent to those skilled in the art. It is therefore to be 
understood that this invention may be practiced otherwise than as 
specifically described. Thus, the present embodiments of the 
invention should be considered, in all respects as illustrative and 
not restrictive, the scope of the invention to be determined by the 
appended claims and their equivalents. 
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WHAT IS CLAIMED IS: 

1. An integrated circuit comprising: 
an input for receiving video data; 

5 an input for receiving graphics data; 

a display engine for blending a plurality of graphics 
layers using alpha values; and 

a video compositor coupled to the display engine for 
blending the graphics data and video data using alpha values, and 
10 for providing a blended output of video and graphics, 

wherein the graphics data is spatially processed 
independently of the video data prior to blending. 

2 . The integrated circuit of claim 1 wherein the video data 
15 includes analog video data. 

3. The integrated circuit of claim 2 wherein the analog 
video data is in a format selected from PAL, NTSC, S-video and 
SECAM formats. 

20 

4 . The integrated circuit of claim 2 wherein the video data 
includes bypass video, the bypass video is the analog video data 
that has been digitized externally to the integrated circuit. 

25 5. The integrated circuit of claim 1 wherein the video data 

includes digital video data. 

6. The integrated circuit of claim 5 wherein the digital 
video data is a decoded MPEG video. 

30 



130 



WO 00/28518 



PCT/US99/26484 



7. The integrated circuit of claim 1 wherein the display 
engine converts the graphics data into a common format, the common 
format including a YUV format. 

8 . The integrated circuit of claim 7 wherein the display 
engine comprises an RGB to YUV converter for converting the 
graphics data from an RGB format to the YUV format. 

9. The integrated circuit of claim 7 wherein the display 
engine comprises a CLUT for converting the graphics data from a 
CLUT format to the YUV format. 

10. The integrated circuit of claim 7 wherein the common 
format is an aYUV 4:4:4:4 format, and the display engine comprises 
a YUV444-to-YUV422 converter for converting the graphics data from 
the aYUV 4:4:4:4 format to the aYUV 4:4:2:2 format. 

11. The integrated circuit of claim 1 wherein the spatial 
processing includes filtering. 

12. The integrated circuit of claim 1 wherein the spatial 
processing includes scaling. 

13. The integrated circuit of claim 1 further comprising a 
scaler engine for upscaling and downscaling. 

14. The integrated circuit of claim 13 wherein the scaler 
engine comprises a vertical filter with programmable coefficients 
for upscaling and downscaling vertically. 
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15. The integrated circuit of claim 13 wherein the scaler 
engine comprises a horizontal filter with programmable coefficients 
for upscaling and downscaling horizontally. 

16. The integrated circuit of claim 1 further comprising a 
graphics accelerator for performing graphics operations. 

17 . The integrated circuit of claim 1 further comprising an 
I/O bus for coupling a CPU with one or more peripheral devices. 

18. The integrated circuit of claim 1 further comprising an 
audio engine for processing an audio input to generate an audio 
output . 

19. The integrated circuit of claim 1 wherein the integrated 
circuit uses a unified memory system. 

20. The integrated circuit of claim 1 further comprising a 
data structure for representing graphics images arranged in logical 
surfaces for display, the data structure comprising 

a field indicating relative depth of the logical surface 
on the display, 

a field indicating an alpha value for the graphics on the 
logical surface, 

a field indicating a location of the logical surface on 
the display, and 

a field indicating a location in memory where graphics 
image data for the logical surface is stored, 

wherein the graphics data include graphics images and the 
logical surfaces are associated with the plurality of graphics 
layers . 
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21. The integrated circuit of claim 1 further comprising a 
graphics window control data passing mechanism comprising 

a window controller for sorting data, the data being used 
5 to describe windows, according to the depth of the window on the 
display, 

wherein the display engine receives the sorted data from 
the window controller and graphics images from memory and blends 
the graphics images using alpha values associated with the graphics 
10 images, and wherein the graphics data includes the graphics images. 

22. The integrated circuit of claim 1 further comprising a 
CLUT loading mechanism comprising 

a window controller for sorting data, the data being 
15 formatted into data structures and used to describe windows, 

according to the depth of the window on the display, 

a CLUT for receiving conversion data from memory, and 
a direct memory access module for transferring the 

conversion data from memory to the CLUT. 

20 

23. The integrated circuit of claim 1 further comprising a 
plurality of line buffers for receiving graphics contents, 

wherein the display engine receives the graphics data 
including raw graphics data and converts the raw graphics data into 
25 the graphics contents having a common format, and the graphics 
contents are composited into each of the plurality of line buffers 
by blending the graphics contents associated with graphics surfaces 
with the existing contents of the line buffer until all graphics 
surfaces for that line has been composited. 

30 
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24. The integrated circuit of claim 1 further comprising- a 
direct memory access module for transferring the graphics data 
including raw graphics data from memory to the display engine, 

wherein the display engine receives the raw graphics data 
and converts the raw graphics data into graphics contents, and the 
display engine is capable of selectively blanking out one or more 
pixels associated with the raw graphics data. 

25. The integrated circuit of claim 1 further comprising a 
low pass filter for filtering a graphical element to generate 
multi-level values, one multi-level value per each pixel, at an 
intended final display resolution and 

a display buffer for storing the multi-level values, 
wherein the display engine composites the multi-level 
values with graphics images that are included in the graphics data. 

26. The integrated circuit of claim 1 further comprising a 
video synchronizing mechanism comprising 

a first sample rate converter for converting a sampling 
rate of a stream of video samples to a first converted rate, 

a filter for processing at least some of the video 
samples with the first converted rate, and 

a second sample rate converter for converting the first 
converted rate to a second converted rate, 

wherein the stream of video samples is included in the 
video data. 

27. The integrated circuit of claim 1 further comprising a 
video scaler comprising 



WO 00/28518 



PCT/US99/26484 



a scaler engine for performing both upscaling and 
downscaling of video images, the video images being included in the 
video data, 

wherein the scaler engine processes the video images 
5 either before writing the video images to memory or after reading 
the video images from memory. 

28. The integrated circuit of claim 1 wherein the display 
engine blends a plurality of graphics images included in the 
10 graphics data into a blended graphics image and combines a 
plurality of alpha values into a plurality of composite alpha 
values, and the video compositor blends the blended graphics image 
with video included in the video data. 

15 29. The integrated circuit of claim 1 further comprising a 

graphics filter having means for spatially processing the graphics 
data, the means for spatially processing the graphics data being 
comprised of means for scaling graphics and means for performing 
anti-flutter filtering, wherein the means for performing anti- 

20 flutter filtering is same as the means for scaling video. 

30. The integrated circuit of claim 1 further comprising a 
unified memory system comprising a memory that is shared by a 
plurality of devices, and 

25 a memory request arbiter coupled to the memory, wherein the 

memory request arbiter performs real time scheduling of memory 
requests from different devices having different priorities, the 
unified memory system assures real time scheduling of tasks, some 
of which do not inherently have pre-determined periodic behavior 

30 and provides access to memory by requesters that are sensitive to 
latency and do not have determinable periodic behavior. 
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31. The integrated circuit of claim 1 further comprising a 
graphics accelerator having a memory for graphics data, the 
graphics data including pixels, and 
5 a coprocessor for performing vector type operations on a 

plurality of components of one pixel of the graphics data. 



32. A method of blending graphics data and video data in an 
10 integrated circuit comprising the steps of: 

receiving the graphics data into the integrated circuit; 

receiving the video data into the integrated circuit; 

blending the graphics data in the integrated circuit 
using alpha values; and 
15 blending the graphics data and the video data in the 

integrated circuit using alpha values. 

33. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 

20 spatially processing the graphics data in the integrated circuit 
prior to blending the graphics data with the video data. 

34. The method of blending graphics data and video data in an 
integrated circuit of claim 32 wherein the graphics data comprises 

25 a plurality of graphics images arranged in a plurality of logical 
surfaces, wherein each of the plurality of graphics images is 
arranged in one of the plurality of logical surfaces. 

35. The method of blending graphics data and video data in an 
30 integrated circuit of claim 34 wherein the step of blending the 

graphics data in the integrated circuit comprises blending the 
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plurality of graphics images from the back most logical surface to 
the front most logical surface, one at a time. 

36. The method of blending graphics data and video data in an 
5 integrated circuit of claim 34 wherein the step of blending the 

graphics data in the integrated circuit comprises blending the 
plurality of graphics images in parallel, two or more at a time. 

37. The method of blending graphics data and video data in an 
10 integrated circuit of claim 32 further comprising the step of using 

a data structure to represent graphics images arranged in logical 
surfaces for display, the step of using a data structure to 
represent graphics images further comprising the steps of 

indicating, in the data structure, relative depth of the 
15 logical surface on the display, 

indicating, in the data structure, an alpha value for the 
graphics on the logical surface, 

indicating, in the data structure, a location of the 
logical surface on the display, and 
20 indicating, in the data structure, a location in memory 

where graphics image data for the logical surface is stored, 

wherein the graphics data includes the graphics image 

data. 

25 38. The method of blending graphics data and video data in an 

integrated circuit of claim 32 further comprising the step of 
processing graphics images for display, the step of processing 
graphics images for display comprising the steps of 

organizing the graphics images into windows in which the 
30 graphics images appear on the screen, 

obtaining data that describe the windows, 

1 37 
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sorting the data according to the depth of the window on 
the display, and 

transferring graphics images from memory, 
wherein the graphics data includes graphics images, and 
5 the graphics data is blended in the integrated circuit using alpha 
values associated with the graphics images included in the graphics 
data. 

39. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 
processing the graphics data in a display engine that processes 
graphics images formatted in a plurality of formats including a 
color look up table (CLUT) format, the step of processing the 
graphics data in the display engine comprising the steps of 
providing a data structure that describes the graphics in a window, 

providing a data structure that provides an indicator to load 
a CLUT, 

sorting the data structures into a list, according to the 
location of the window on the display, and 

loading conversion data into a CLUT, for converting the CLUT- 
formatted data into a different data format, according to the 
sequence of data structures on the list. 

40. The method of blending graphics data and video data in an 
25 integrated circuit of claim 32 wherein the graphics data includes 

a plurality of graphics images and the step of blending the 
graphics data in the integrated circuit comprises the step of 
blending the plurality of graphics images comprising the steps of 
initializing a line buffer by loading the line buffer with data 
30 that represent transparent black, 
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obtaining control of a line buffer for a compositing 

operation, 

compositing graphics contents into the line buffer by 
blending the graphics contents with the existing contents of the 
5 line buffer, and 

repeating the step of compositing graphics contents into the 
line buffer until all graphics surfaces for that line have been 
composited . 

10 41. The method of blending graphics data and video data in an 

integrated circuit of claim 32 further comprising the step of 
horizontally scrolling a display window to the left, the step of 
horizontally scrolling a display window to the left comprising the 
steps of blanking out one or more pixels at a beginning of a 

15 portion of graphics data, the portion being aligned with a start 
address, and 

displaying the graphics data starting at the first non-blanked 
out pixel in the portion of the graphics data aligned with the 
start address. 

20 

42. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 
horizontally scrolling a display window to the right, the step of 
horizontally scrolling a display window to the right comprising the 
25 steps of moving a read pointer to a new start address that is 
immediately prior to a current start address, 

blanking out one or more pixels at a beginning of a 
portion of graphics data, the portion being aligned to the new 
start address, and 
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displaying the graphics data starting at the first non- 
blanked out pixel in the portion of the graphics data aligned with 
the new start address. 

5 43. The method of blending graphics data and video data in an 

integrated circuit of claim 32 further comprising the step of 
displaying a graphical element, the step of displaying a graphical 
element comprising the steps of filtering the graphical element 
with a low pass filter to generate a multi-level value per pixel at 
10 an intended final display resolution, and 

using the multi-level values as alpha blend values for 
the graphical element in a subsequent compositing stage. 

44. The method of blending graphics data and video data in an 
15 integrated circuit of claim 32 further comprising the step of 

synchronizing video, the step of synchronizing video comprising the 
steps of converting a sampling rate of a stream of video samples to 
a first converted rate, 

processing at least some of the video samples having the 
20 first converted rate, and 

converting the first converted rate to a second converted 

rate, 

wherein the video data includes the stream of video 

samples . 

25 

45. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 
scaling a video image included in the video data, the step of 
scaling a video image comprising the steps of determining whether 

30 it will require less memory bandwidth to scale the video image 
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before writing the video image to memory or after reading the video 
image from memory, and 

scaling the video image with a scaler engine, 

wherein the scaler engine scales the video image either 
5 before writing the video image to memory or after reading the video 
image from memory, depending on which operation requires less 
memory bandwidth. 

46. The method of blending graphics data and video data in an 
10 integrated circuit of claim 32 further comprising the step of 

combining a plurality of alpha values into a plurality of composite 
alpha values, 

wherein the step of blending the graphics data in the 
integrated circuit using alpha values comprises the step of 
15 blending the plurality of graphics images into a blended graphics 
image, and 

the step of blending the graphics data and the video data in 
the integrated circuit using alpha values comprises the step of 
blending the blended graphics image and the video using the 
20 plurality of composite alpha values. 

47. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 
performing anti-flutter filtering and graphics scaling, the step of 

25 performing anti-flutter filtering and graphics scaling comprising 
the steps of providing a plurality of display lines to a graphics 
filter, and performing graphics scaling and anti-flutter filtering 
simultaneously using the graphics filter. 

30 48. The method of blending graphics data and video data in an 

integrated circuit of claim 32 further comprising the step of 
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designing real time scheduling, the step of designing real time 
scheduling comprising the steps of running a critical instant 
analysis, 

ordering periods of different tasks from the shortest to 
5 the longest, 

assigning priorities based on the order in accordance to 
the duration of the periods, 

selecting tasks that are non-periodic but requires 
expedited servicing, assigning high priorities to them, and 
10 imposing a minimum interval between successive accesses by these 
tasks, and 

assigning low priority to non-periodic tasks, that do not 
require expedited servicing, to be serviced in a round robin 
manner . 

15 

49. The method of blending graphics data and video data in an 
integrated circuit of claim 32 further comprising the step of 
processing graphics, the step of processing graphics comprising the 
steps of loading the graphics data into a graphics accelerator 
20 having a coprocessor, the graphics data including pixels, each 
pixel having a plurality of components, and performing vector type 
operations on the plurality of components of each pixel of graphics 
data using the coprocessor. 

25 50. A data structure for representing graphics images 

arranged in logical surfaces for display, the data structure 
comprising : 

a field indicating relative depth of the logical surface 
on the display; 

30 a field indicating an alpha value for the graphics on the 

logical surface; 
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a field indicating a location of the logical surface" on 
the display; and 

a field indicating a location in memory where graphics 
image data for the logical surface is stored. 

5 

51. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, the data 
structure further comprising a field indicating a format of the 
graphics data to be displayed on the window. 

10 

52. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 51 wherein the 
format of the graphics data to be displayed on the window is 
selected from YUV, RGB, CLUT and alpha-only formats. 

15 

53. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 52 wherein the 
alpha-only format is a format in which the graphics data represent 
alpha values only. 

20 

54 . The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, the data 
structure further comprising a field indicating a method of 
selecting an alpha value for each pixel in the graphics images. 

25 

55. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 54 wherein the 
alpha value for each pixel is selected using chroma keying, CLUT 
alpha values, luminance (Y) values or a window alpha value. 

30 
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56. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, wherein the 
alpha value contained in the field indicating the alpha value is 
applied to all pixels of a graphics image on one of the logical 
5 surfaces. 



57 . The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, the data 
structure further comprising' a field indicating a method of 
10 selecting an alpha value for each pixel in the graphics images. 



58 . The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, the data 
structure- further comprising a field indicating a color of the 
15 logical surface described by the data structure. 



20 



59. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, wherein the 
graphics image is comprised of pixels having a single color. 



60. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 59, wherein the 
alpha value contained in the field indicating the alpha value is 
applied to all pixels of a graphics image on one of the logical 
25 surfaces. 



61. The data structure for representing graphics images 
arranged in logical surfaces for display of claim 50, the data 
structure further comprising a field indicating the number of 
30 pixels to be blanked out at the beginning of the display line. 
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62. A method of using a data structure to represent graphics 
images arranged in logical surfaces for display comprising the 
steps of: 

indicating, in the data structure, relative depth of the 
5 logical surface on the display; 

indicating, in the data structure, an alpha value for the 
graphics on the logical surface; 

indicating, in the data structure, a location of the 
logical surface on the display; and 
10 indicating, in the data structure, a location in memory 

where graphics image data for the logical surface is stored. 

63. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 

15 62 further comprising the step of indicating, in the data 
structure, a format of the graphics data to be displayed on the 
window . 

64. The method of using a data structure to represent 
20 graphics images arranged in logical surfaces for display of claim 

63 wherein the format of the graphics data to be displayed on the 
window is selected from YUV, RGB, CLUT and alpha-only formats. 

65. The method of using a data structure to represent graphics 
25 images arranged in logical surfaces for display of claim 64 wherein 

the alpha-only format is a format in which the graphics data 
represent alpha values only. 

66. The method of using a data structure to represent 
30 graphics images arranged in logical surfaces for display of claim 

62 further comprising the step of indicating, in the data 
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structure, a method of selecting an alpha value for each pixel "in 
the graphics images. 



67. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 
66 wherein the alpha value for each pixel is selected using chroma 
keying, GLUT alpha values, luminance (Y) values or a window alpha 
value . 



68. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 
62 further comprising the step of applying the alpha value for the 
graphics in the logical surface to all pixels of a graphics image 
on one of the logical surfaces. 



69. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 
62 further comprising the step of indicating, in the data 
structure, a method of selecting an alpha value for each pixel in 
the graphics images . 



70. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 
62 further comprising the step of indicating, in the data 
structure, a color of the logical surface described by the data 
structure . 



71. The method of using 
graphics images arranged in logi 
62, wherein the graphics image 
single color. 



a data structure to represent 
cal surfaces for display of claim 
is comprised of pixels having a 
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72. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 
71, wherein the alpha value for the graphics on the logical surface 

5 is applied to all pixels of a graphics image on one of the logical 
surfaces . 

73. The method of using a data structure to represent 
graphics images arranged in logical surfaces for display of claim 

10 62 further comprising the step of indicating, in the data 
structure, a field indicating the number of pixels to be blanked 
out at the beginning of the display line. 

74. A method of processing graphics images for display, the 
15 method comprising the steps of: 

organizing the graphics images into windows in which the 

graphics images appear on the screens- 
obtaining data that describe the windows; 
sorting the data according to the depth of the window on 
20 the displays- 
transferring graphics images from memory; and 
blending the graphics images using alpha values 

associated with the graphics images. 

25 75. The method of processing graphics images for display of 

claim 73 wherein the step of organizing the graphics images into 
windows is performed by software prior to obtaining the data from 
memory . 

30 76. The method of processing graphics images for display of 

claim 74 further comprising the step of sorting the windows from 
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top to bottom, i.e., from the window that starts first vertically 
on the screen to the window that starts last vertically on the 
screen . 

5 77. The method of processing graphics images for display of 

claim 74 further comprising the step of sorting the windows from 
left to right, i.e., from the window that starts first horizontally 
on the screen to the window that starts last horizontally on the 
screen. 

10 

78. The method of processing graphics images for display of 
claim 74 wherein the step of sorting the windows from top to bottom 
is performed by software prior to obtaining the data from memory. 

15 79. The method of processing graphics images for display of 

claim 74 wherein the step of sorting the data according to the 
depth of the window on the display is performed in hardware after 
the data is obtained from memory. 

20 80. The method of processing graphics images for display of 

claim 74 wherein the step of sorting the data according to the 
depth of the window on the display is performed by software prior 
to obtaining the data from memory. 

25 81. The method of processing graphics images for display of 

claim 74 wherein the step of sorting the data according to the 
depth of the window on the display comprises the step of sorting 
the data in an order from the back most window to the front most 
window . 

30 
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82. The method of processing graphics images for display of 
claim 81 wherein the step of sorting the data according to the 
depth of the window on the display further comprises the step of 
sorting the data based on which windows have been processed on a 

5 current display line. 

83. The method of processing graphics images for display of 
claim 74 further comprising the step of transferring the sorted 
data to the display engine to initiate the transfer of graphics 

10 images from memory. 

84. The method of processing graphics images for display of 
claim 83 further comprising the step of processing the sorted data 
in the display engine to control the step of blending the graphics 

15 images. 

85. The method of processing graphics images for display of 
claim 74 wherein the step of transferring graphics images from 
memory comprises the step of transferring the graphics images into 

20 a FIFO and transferring the graphics images from the FIFO to a 
graphics converter. 

86. The method of processing graphics images for display of 
claim 85 wherein FIFO writing and FIFO reading are performed in two 

25 different time domains. 

87. The method of processing graphics images for display of 
claim 86 wherein FIFO writing is performed synchronously to a 
memory clock. 

30 
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88. The method of processing graphics images for display -of 
claim 86 wherein FIFO reading is performed asynchronously to the 
memory clock. 

5 89. The method of processing graphics images for display of 

claim 88 wherein FIFO reading is performed synchronously to a 
graphics processing clock. 

90. The method of processing graphics images for display of 
10 claim 74 wherein the step of transferring graphics images from 

memory comprises the step of transferring the graphics images 
directly from memory to a graphics converter. 

91. A graphics window control data passing mechanism 
15 comprising: 

A window controller for sorting data, the data being 
used to describe windows, according to the depth of the window on 
the display; and 

A display engine for receiving the sorted data from 
20 the window controller and graphics images from memory and blending 
the graphics images using alpha values associated with the graphics 
images. 

92. The graphics window control data passing mechanism of 
25 claim 91 wherein the data used to describe the windows is organized 

into windows in which the graphics images appear on the screen 
prior to being transferred into the window controller. 

93. The graphics window control data passing mechanism of 
30 claim 91 wherein the window controller sorts in an order from the 

back most window to the front most window. 



150 



WO 00/28518 



PCT/US99/26484 



94. The graphics window control data passing mechanism 
claim 91 wherein the window controller sorts the data based 
which windows have been processed on a current display line. 

5 

95. The graphics window control data passing 
claim 91 wherein the display engine comprises a FIFO 
the graphics images from memory. 

10 96. The graphics window control data passing mechanism of 

claim 95 wherein the FIFO has a write port and a read port, and 
wherein the write port is synchronous to a memory clock and the 
read port is asynchronous to the memory clock. 

15 97. The graphics window control data passing mechanism of 

claim 96 wherein the read port is synchronous to a graphics 
processing clock. 

98. The graphics window control data passing mechanism of 
20 claim 91 wherein the display engine comprises a graphics converter, 

and wherein the graphics converter receives the graphics images 
directly from memory. 

99. A method of processing graphics data in a display engine 
25 that processes graphics images formatted in a plurality of formats 

including a color look up table (CLUT) format, the method 
comprising the steps of: 

providing a data structure that describes the graphics in a 
window; 

30 providing a data structure that provides an indicator to load 

a CLUT; 



mechanism of 
for receiving 
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sorting the data structures into a list, according to the 
location of the window on the display; and 

loading conversion data into a CLUT, for converting the CLUT- 
formatted data into a different data format, according to the 
5 sequence of data structures on the list. 

100. The method of processing graphics data in a display 
engine of claim 99 wherein the data structure that describes the 
graphics in a window has a format similar to the data structure 

10 that provides the indicator to load a CLUT. 

101. The method of processing graphics data in a display 
engine of claim 99 wherein the step of sorting the data structures 
into a list comprises sorting based on the location on the screen 

15 of the windows that corresponds to the data structures. 

102. The method of processing graphics data in a display 
engine of claim 101 wherein the step of sorting the data structures 
into a list comprises sorting from top to bottom, i.e., from the 

20 data structure that corresponds to a window that starts first 
vertically on the screen to the window that starts last vertically 
on the screen. 

103. The method of processing graphics data in a display 
-25 engine of claim 101 wherein the step of sorting the data structures 

into a list comprises sorting from back to front, i.e., from the 
data structure that corresponds to the back most window to the data 
structure that corresponds to the front most window. 

30 104. The method of processing graphics data in a display 

engine of claim 101 wherein the step of sorting the data structures 
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into a list comprises sorting from left to right, i.e., from the 
data structure that corresponds to a window that starts first 
horizontally to the data structure that corresponds to a window 
that starts last horizontally. 

5 

105. The method of processing graphics data in a display 
engine of claim 99 wherein the data structure that provides an 
indicator to load a CLUT also indicates location in memory of the 
conversion data to be loaded. 

10 

106. The method of processing graphics data in a display 
engine of claim 99 wherein the data structure that provides an 
indicator to load a CLUT also indicates the size of the conversion 
data to be loaded into the CLUT. 

15 

107. The method of processing graphics data in a display 
engine of claim 99 wherein the data structure that provides an 
indicator to load a CLUT also indicates when to load the CLUT. 



20 108. The method of processing graphics data in a display 

engine of claim 99 wherein graphics data on a plurality of windows, 
the plurality of windows having CLUT-f ormatted data with different 
formats, can be processed and displayed on the same display line. 



25 109. The method of processing graphics data in a display 

engine of claim 99 wherein the conversion data includes a plurality 
of portions, and the step of loading conversion data into a CLUT 
comprises loading one or more of the plurality of portions of the 
conversion data. 

30 

110. A CLUT loading mechanism comprising: 
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A window controller for sorting data, the data being 
formatted into data structures and used to describe windows, 
according to the depth of the window on the display; 

A CLUT for receiving conversion data from memory; and 
5 A direct memory access module for transferring the 

conversion data from memory to the CLUT. 

111. The CLUT loading mechanism of claim 110 further 
comprising a display engine for receiving the sorted data from the 

10 window controller and prompting the direct memory access module to 
transfer the conversion data to the CLUT. 

112. The CLUT loading mechanism of claim 110 wherein the 
timing of transferring the conversion data from memory to the CLUT 

15 is determined by the data structures. 

113. The CLUT loading mechanism of claim 110 wherein the data 
structures comprise a data structure that describes the graphics in 
a window. 

20 

114. The CLUT loading mechanism of claim 113 wherein the data 
structures further comprise a data structure that provides an 
indicator to transfer the conversion data from memory to the CLUT. 

25 115. The CLUT loading mechanism of claim 114 wherein the data 

structure that describes the graphics in a window has a format 
similar to the data structure that provides the indicator to 
transfer the conversion data from memory to the CLUT. 

30 116. The CLUT loading mechanism of claim 114 wherein the data 

structure that provides an indicator to transfer the conversion 
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data from memory to the CLUT also indicates location in memory "of 
the conversion data to be loaded. 

117. The CLUT loading mechanism of claim 114 wherein the data 
5 structure that provides an indicator to transfer the conversion 

data from memory to the CLUT also indicates the size of the 
conversion data to be loaded into the CLUT. 

118. The CLUT loading mechanism of claim 114 wherein the data 
10 structure that provides an indicator to transfer the conversion 

data from memory to the CLUT also indicates when to load the CLUT. 

119. The CLUT loading mechanism of claim 111 wherein the 
display engine comprises a FIFO for receiving the sorted data from 

15 the window controller , the FIFO provides the sorted data as output. 

120. The CLUT loading mechanism of claim 119 wherein the FIFO 
has a write port and a read port, wherein the write port is 
synchronous to a memory clock while the read port is asynchronous 

20 to the memory clock. 

121. The CLUT loading mechanism of claim 120 wherein the read 
port is synchronous to a graphics processing clock. 

25 122. The CLUT loading mechanism of claim 121 wherein the 

display engine further comprises a graphics converter for receiving 
the sorted data from the FIFO. 

123. The CLUT loading mechanism of claim 111 wherein the 
30 display engine comprises a graphics converter, and wherein the 
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sorted data is transferred from the window controller to the 
graphics converter directly. 

124. A method of blending a plurality of graphics images, the 
5 method comprising the steps of: 

initializing a line buffer by loading the line buffer 
with data that represent transparent black; 

obtaining control of a line buffer for a compositing 

operation; 

10 compositing graphics contents into the line buffer by 

blending the graphics contents with the existing contents of the 
line buffer; and 

repeating the step of compositing graphics contents into 
the line buffer until all graphics surfaces for that line have been 

15 composited. 

125. The method of blending a plurality of graphics images of 
claim 124 wherein the step of obtaining control of line buffer for 
a composition operation takes place at a video inactive region. 

20 

126. The method of blending a plurality of graphics images of 
claim 124 wherein the step of obtaining control of a line buffer 
comprises clock switching, which is synchronizing the line buffer 
to a clock. 

25 

127. The method of blending a plurality of graphics images of 
claim 126 wherein the clock is a memory clock. 

128. The method of blending a plurality of graphics images of 
30 claim 126 wherein the clock is a graphics processing clock. 
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129. The method of blending a plurality of graphics images of 
claim 124 further comprising the step of releasing control of the 
line buffer after all graphics surfaces for that line has been 
composited. 

5 

130. The method of blending a plurality of graphics images of 
claim 129 wherein the step of releasing control of the line buffer 
takes place at a video inactive region. 

10 131. The method of blending a plurality of graphics images of 

claim 129 wherein the step of releasing control of the line buffer 
comprises clock switching, which is to synchronize the line buffer 
to a display clock. 

15 132. The method of blending a plurality of graphics images of 

claim 124 further comprising the step of blending video to the 
blended graphics after all graphics surfaces for that line have 
been composited. 

20 133. The method of blending a plurality of graphics images of 

claim 124 further comprising the step of spatially filtering the 
blended graphics after all graphics surfaces for that line has been 
composited . 

25 134. The method of blending a plurality of graphics images of 

claim 124 wherein the step of compositing graphics contents into 
the line buffer comprises the step of alpha blending the graphics 
contents with the existing contents of the line buffer. 

30 135. The method of blending a plurality of graphics images of 

claim 134 wherein the step of compositing graphics contents into 
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the line buffer further comprises blending alpha values of the 
graphics contents with corresponding intermediate alpha values of 
the existing contents of the line buffer into new intermediate 
alpha values, wherein each new intermediate alpha value is a 
5 product of (1-alpha value) associated with each pixel of the 
graphics contents and the corresponding intermediate alpha value. 

136. The method of blending a plurality of graphics images of 
claim 134 wherein the step of alpha blending the graphics contents 
10 with the existing contents of the line buffer comprises the steps 
of multiplying the existing contents of the line buffer by (1-alpha 
value) , multiplying the graphics contents by alpha, and adding 
products of the two multiplications. 

15 137. A graphics display system comprising: 

a display engine for receiving raw graphics data and 
converting the raw graphics data into graphics contents having a 
common format; and 

a plurality of line buffers for receiving the 
20 graphics contents, 

wherein the graphics contents are composited into 
each of the plurality of line buffers by blending the graphics 
contents associated with graphics surfaces with the existing 
contents of the line buffer until all graphics surfaces for that 
25 line has been composited. 

138. The graphics display system of claim 137 wherein the 
plurality of line buffers implemented on a single-port random 
access memory (RAM) . 

30 
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139. The graphics display system of claim 137 wherein the 
graphics surfaces are composited into the line buffer, one at a 
t ime . 

5 140. The graphics display system of claim 137 wherein two or 

more graphics surfaces are composited into the line buffer at a 
time . 

141. The graphics display ' system of claim 137 wherein each of 
10 the plurality of line buffers operates in a plurality of time 

domains . 

142. The graphics display system of claim 141 wherein each of 
the plurality of line buffers switches between a plurality of time 

15 domains through clock switching. 

143. The graphics display system of claim 142 wherein clock 
switching takes places at a video inactive region. 

20 144. The graphics display system of claim 141 wherein the 

plurality of time domains includes a memory clock domain. 

145. The graphics display system of claim 141 wherein the 
plurality of time domains includes a display clock domain. 

25 

146. The graphics display system of claim 141 wherein the 
plurality of time domains includes a graphics processing clock 
domain . 

30 147. The graphics display system of claim 141 further 
comprising a graphics filter for receiving and filtering contents 
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of the line buffer after all graphics surfaces for that line has 
been composited. 

148. The graphics display system of claim 147 wherein the 
5 graphics filter clears one or more line buffers by loading them 

with transparent black pixels if those one or more line buffers 
will not be used for generating a next display line. 

149. The graphics display system of claim 144 wherein each of 
10 the plurality of line buffers operates in the memory clock domain 

while the graphics surfaces are composited into that line buffer. 

150. The graphics display system of claim 146 wherein each of 
the plurality of line buffers operates in the graphics processing 

15 clock domain while the graphics surfaces are composited into that 
line buffer. 

151. The graphics display system of claim 145 wherein each of 
the plurality of line buffers operates in the display clock domain 

20 while contents of that line buffer is being provided to the 
graphics filter. 

152. The graphics display system of claim 147 wherein the 
contents from two or more of the plurality of line buffers are 

25 provided to the graphics filter at the same time for filtering. 

153. The graphics display system of claim 137 wherein the 
common format is selected from a group consisting of YUV and RGB 
formats . 

30 
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154. A method of blending a plurality of graphics images, the 
method comprising the steps of: 

initializing a plurality of line buffers by loading the 
line buffers with data that represent transparent black; 
5 obtaining control of one or more of the plurality of line 

buffers for compositing operations; 

compositing graphics contents into the one or more of the 
plurality of line buffers by blending the graphics contents 
with the existing contents of the line buffers; and 
10 repeating the step of compositing graphics contents into 

the line buffers until all graphics surfaces for the lines 
corresponding to the line buffers have been composited. 

155. A method of horizontally scrolling a display window to 
15 the left comprising the steps of: 

blanking out one or more pixels at a beginning of a 
portion of graphics data, the portion being aligned with a start 
address; and 

displaying the graphics data starting at the first non- 
20 blanked out pixel in the portion of the graphics data aligned with 
the start address. 

156. The method of horizontally scrolling a display window to 
the left of claim 155 further comprising the step of converting the 

25 graphics data into a common format. 

157. The method of horizontally scrolling a display window to 
the left of claim 155 wherein the step of blanking out one or more 
pixels comprise the step of blanking out one or more bits. 

30 
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158. The method of horizontally scrolling a display window to 
the left of claim 156 wherein the common format is selected from 
the group of YUV and RGB formats. 

5 159. The method of horizontally scrolling a display window to 

the left of claim 155 wherein each pixel is comprised of one or 
more bits. 

160. The method of horizontally scrolling a display window to 
10 the left of claim 159 wherein the number of bits per pixel is 

selected from the group consisting of 1 bit, 2 bits, 4 bits, 8 
bits, 16 bits, 24 bits and 32 bits. 

161. A method of horizontally scrolling a display window to 
the right comprising the steps of: 

moving a read pointer to a new start address that is 
immediately prior to a current start address; 

blanking out one or more pixels at a beginning of a 
portion of graphics data, the portion being aligned to the new 
start address; and 

displaying the graphics data starting at the first non- 
blanked out pixel in the portion of the graphics data aligned with 
the new start address. 

25 162. The method of horizontally scrolling a display window to 

the right of claim 161 further comprising the step of converting 
the graphics data into a common format. 

163. The method of horizontally scrolling a display window to 
30 the right of claim 161 wherein the step of blanking out one or more 
pixels comprise the step of blanking out one or more bits. 

162 
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164. The method of horizontally scrolling a display window to 
the right of claim 162 wherein the common format is selected from 
the group of YUV and RGB formats. 

5 

165. The method of horizontally scrolling a display window to 
the right of claim 161 wherein each pixel is comprised of one or 
more bits. 

10 166. The method of horizontally scrolling a display window to 

the right of claim 165 wherein the number of bits per pixel is 
selected from the group consisting of 1 bit, 2 bits, 4 bits, 8 
bits, 16 bits, 24 bits and 32 bits 



15 167. A graphics display system comprising: 

a display engine for receiving raw graphics data and 
converting the raw graphics data into graphics contents; and 

a direct memory access module for transferring the raw 
graphics data from memory to the display engine, 
20 wherein the display engine is capable of selectively 

blanking out one or more pixels associated with the raw graphics 
data . 



168. The graphics display system of claim 167 wherein the 
25 display engine comprises means for blanking out one or more pixels 
associated with the raw graphics data. 



169. The graphics display system of claim 168 wherein the 
direct memory access module is used to transfer the raw graphics 
30 data from memory starting at a start address. 
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170. The graphics display system of claim 169 wherein the 
blanking out means is used to blank out one or more pixels from a 
portion of the raw graphics data, wherein the portion is aligned 
with the start address. 

5 

171. The graphics display system of claim 168 wherein the 
direct memory access module is used to transfer the raw graphics 
data from memory starting at a new start address, wherein the new 
start address is the address that is immediately prior to a current 

10 start address. 

172. The graphics display system of claim 171 wherein the 
blanking out means is used to blank out one or more pixels from a 

15 portion of the raw graphics data, wherein the portion is aligned 
with the new start address. 

173. A method of displaying a graphical element comprising the 
steps of: 

20 filtering the graphical element with a low pass filter to 

generate a multi-level value per pixel at an intended final display 
resolution; and 

using the multi-level values as alpha blend values for 
the graphical element in a subsequent compositing stage. 

25 

174. The method of displaying a graphical element of claim 173 
wherein the multi-level values are written into a display buffer 
where the multi-level values are used as alpha blend values when 
contents of the display buffer are composited with other graphics 

30 and video images. 
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175. The method of displaying a graphical element of claim 173 
wherein the graphical element is initially rendered at a higher 
resolution than the intended final display resolution. 

5 17 6. The method of displaying a graphical element of claim 175 

wherein the graphical element is initially rendered at four times 
the resolution of the intended final display resolution in a 
horizontal axis. 

10 177. The method of displaying a graphical element of claim 175 

wherein the graphical element is initially rendered at four times 
the resolution of the intended final display resolution in a 
vertical axis. 

15 178. The method of displaying a graphical element of claim 173 

wherein the low pass filter is a box filter. 

17 9. The method of displaying a graphical element of claim 173 
wherein the graphical element includes text, and the display buffer 
20 is defined to have a constant foreground color that is consistent 
with a desired foreground color of the text. 

180. The method of displaying a graphical element of claim 173 
wherein the graphical element includes graphics, and the display 

25 buffer is defined to have a constant foreground color that is 
consistent with a desired foreground color of the graphics. 

181. The method of displaying a graphical element of claim 173 
wherein the alpha blend values include CLUT indexes, each CLUT 

30 index is associated with a CLUT entry, and each CLUT entry contains 
a CLUT alpha blend value. 
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182. The method of displaying a graphical element of claim 173 
wherein the alpha blend values are used to form alpha portions of 
pixels having a color portion and an alpha portion. 

5 

183. The method of displaying a graphical element of claim 182 
wherein the pixels having color portions and alpha portions are in 
an alphaRGB (4,4,4,4) format. 

10 184. The method of displaying a graphical element of claim 183 

wherein the graphical element has a plurality of foreground colors, 
which are filtered using a low pass filter. 

18 5. The method of displaying a graphical element of claim 184 
15 wherein the filtered plurality of foreground colors are used as 
color portions of pixels having a color portion and an alpha 
portion . 

18 6. The method of displaying a graphical element of claim 185 
20 wherein the pixels having a color portion and an alpha portion are 
in an alphaRGB format. 

187. The method of displaying a graphical element of claim 185 
wherein the pixels having a color portion and an alpha portion are 

25 in an alphaYUV format. 

188. The method of displaying a graphical element of claim 184 
wherein the filtered plurality of foreground colors are used as 
color choices in a CLUT format. 

30 
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18 9. The method of displaying a graphical element of claim 173 
wherein an outline of the graphical element, including all colors 
other than background color, is filtered using the low pass filter, 
wherein the graphical element has a plurality of foreground colors. 

5 

190. The method of displaying a graphical element of claim 189 
wherein the filtered outline is used as an alpha per pixel value. 

191. The method of displaying a graphical element of claim 190 
10 wherein the filtered outline is used as the alpha per pixel value 

in a direct color format, the direct color format including an 
alphaRGB format. 

192. The method of displaying a graphical element of claim 190 
15 wherein the filtered outline is used as a choice of an alpha value 

per CLUT entry in a GLUT format. 

193. The method of displaying a graphical element of claim 174 
wherein the step of using the multi-level values as the alpha blend 

20 values for the graphical element in a subsequent compositing stage 
comprises compositing the display buffer with other graphics and 
video contents while blending the display buffer with all layers 
behind it using alpha per pixel values. 

25 194. The method of displaying a graphical element of claim 174 

wherein the opacity of the graphical element may be varied by 
specifying the alpha value of the display buffer. 

195. A graphics display system for displaying a graphical 
30 element comprising: 
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a low pass filter for filtering the graphical element - 
to generate multi-level values, one multi-level value per each 
pixel, at an intended final display resolution; 

a display buffer for storing the multi-level values; 

and 

a display engine for compositing the multi-level values 
with graphics images. 

196. The graphics display system for displaying a graphical 
element of claim 195 wherein the multi-level values are used as 
alpha blend values for blending with the graphics images. 

197. The graphics display system for displaying a graphical 
element of claim 195 wherein the graphical element is initially 
rendered at a higher resolution than the intended final display 
resolution . 

198. The graphics display system of claim 195 wherein the 
low pass filter is a box filter. 

199. The graphics display system of claim 195 wherein the 
graphical element includes text, and the display buffer is 
defined to have a constant foreground color that is consistent 
with a desired foreground color of the text. 

200. The graphics display system of claim 195 wherein the 
graphical element includes graphics, and the display buffer is 
defined to have a constant foreground color that is consistent 
with a desired foreground color of the graphics. 
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201. The graphics display system of claim 196 wherein the 
alpha blend values include CLUT indexes, each GLUT index is 
associated with a CLUT entry, and each CLUT entry contains a CLUT 
alpha blend value. 

5 

202. The graphics display system of claim 196 wherein the 
alpha blend values are used to form alpha portions of pixels 
having a color portion and an alpha portion. 

10 203. The graphics display system of claim 202 wherein the 

pixels having color portions and alpha portions are in an 
alphaRGB (4,4,4,4) format. 



204. The graphics display system of claim 195 wherein the 
15 graphical element has a plurality of foreground colors, which are 
filtered using a low pass filter. 



205. The graphic 
filtered plurality of 
20 portions of pixels ha 



s display system of 

foreground colors a 
ving a color portion 



claim 204 wherein the 
re used as color 
and an alpha portion. 



206. The graphics display system of claim 205 wherein the 
pixels having a color portion and an alpha portion are in an 
alphaRGB format. 

207. The graphics display system of claim 205 wherein the 
pixels having a color portion and an alpha portion are in an 
alphaYUV format. 
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208. The graphics display system of claim 204 wherein the " 
filtered plurality of foreground colors are used as color choices 
in a CLUT format. 

209. The graphics display system of claim 195 wherein an 
outline of the graphical element, including all colors other than 
background color, is filtered using the low pass filter, wherein 
the graphical element has a plurality of foreground colors. 

210. The graphics display system of claim 209 wherein the 
filtered outline is used as an alpha per pixel value. 

211. The graphics display system of claim 210 wherein the 
filtered outline is used as the alpha per pixel value in a direct 
color format, the direct color format including an alphaRGB 
format . 

212. The graphics display system of claim 210 wherein the 
filtered outline is used as a choice of an alpha value per CLUT 
entry in a CLUT format. 

213. The graphics display system of claim 195 wherein the 
translucency of the graphical element is varied by specifying the 
alpha value of the display buffer. 

214. A video synchronizing mechanism comprising: 

a first sample rate converter for converting a sampling 
rate of a stream of video samples to a first converted rate; 

a filter for processing at least some of the video 
samples with the first converted rate; and 
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a second sample rate converter for converting the firs't 
converted rate to a second converted rate. 

215. The video synchronizing mechanism of claim 214 wherein 
5 the output of the second sample rate converter is stored in memory 

such that the output of the memory is running at a display clock 
rate that may differ from the second converted rate. 

216. The video synchronizing mechanism of claim 214 further 
10 comprising a time base corrector for synchronizing the output of 

the second sample rate converter to a display clock, wherein the 
display clock runs at a display clock rate that may differ from the 
second converted rate. 

15 217. The video synchronizing mechanism of claim 214 further 

comprising an analog-to-digital converter (ADC) for providing the 
stream of video samples to the first sample rate converter. 

218. The video synchronizing mechanism of claim 217 wherein 
20 the ADC generates the stream of video samples with the sampling 

rate that is arbitrary. 

219. The video synchronizing mechanism of claim 218 wherein 
the arbitrary sampling rate is greater than four times the chroma 

25 sub-carrier frequency. 

220. The video synchronizing mechanism of claim 214 wherein 
the sampling rate of the stream of video samples is fixed, and the 
stream of video samples is generated using a free-running input 

30 sample clock. 
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221. The video synchronizing mechanism of claim 220 wherein 
the sampling rate of the stream of video samples is variable. 

222. The video synchronizing mechanism of claim 220 wherein 
5 the first sample rate converter comprises a sample rate converter 

for down-sampling the stream of video samples. 

223. The video synchronizing mechanism of claim 222 wherein 
the first sample rate converter further comprises a chroma tracker 

10 for tracking phase and frequency of the chroma bursts and comparing 
them against an expected pattern, and the chroma tracker generates 
an error signal based on the result of the comparison. 

224. The video synchronizing mechanism of claim 223 wherein 
15 the first sample rate converter further comprises a low pass filter 

for filtering the error signal of the chroma tracker and providing 
a first adjustment value to the sample rate converter to adjust the 
first down-sampling ratio, which is the ratio between the sampling 
rate and the first converted rate. 

20 

225. The video synchronizing mechanism of claim 224 wherein 
the first down-sampling ratio is 35/(66 + epsilon) , where epsilon 
is the first adjustment value. 

25 226. The video synchronizing mechanism of claim 225 wherein 

the sampling rate of the stream of video samples is 27 MHz. 

227. The video synchronizing mechanism of claim 226 wherein 
the first converted rate is equal to four times the chroma sub- 
30 carrier frequency. 
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228. The video synchronizing mechanism of claim 227 wherein 
the four times the chroma sub-carrier frequency is about 14.318 
MHz . 

229. The video synchronizing mechanism of claim 227 wherein 
the four times the chroma sub-carrier frequency is about 17.72 MHz. 

230. The video synchronizing mechanism of claim 221 wherein 
the first sample rate converter comprises a sample rate converter 
for down-sampling the stream of video samples. 

231. The video synchronizing mechanism of claim 230 wherein 
the first sample rate converter further comprises a chroma tracker 
for tracking phase and frequency of the chroma bursts and comparing 
them against an expected pattern, wherein the chroma tracker 
generates an error signal based on the result of the comparison. 

232. The video synchronizing mechanism of claim 231 wherein 
the first sample rate converter further comprises a low pass filter 
for filtering the error signal of the chroma tracker and generates 
an output . 

233. The video synchronizing mechanism of claim 232 wherein 
the first sample rate converter further comprises a voltage 
controlled oscillator, wherein the arbitrary sampling rate is an 
oscillation frequency of the voltage controlled oscillator, and the 
voltage controlled oscillator receives the output of the low pass 
filter and uses it to adjust the oscillating frequency. 
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234. The video synchronizing mechanism of claim 233 wherein- a 
first down-sampling ratio of the sample rate converter is fixed at 
35/66. 

5 235. The video synchronizing mechanism of claim 234 wherein 

the first converted rate is equal to four times the chroma sub- 
carrier frequency . 

236. The video synchronizing mechanism of claim 235 wherein 
10 the four times the chroma sub-carrier frequency is about 14.318 

MHz . 

237. The video synchronizing mechanism of claim 235 wherein 
the four times the chroma sub-carrier frequency is about 17.72 MHz. 

15 

238. The video synchronizing 
the filter for processing at least 
the first converted rate includes 
luma/ chroma separation . 

20 

239. The video synchronizing mechanism of claim 238 wherein 
the comb filter is an adaptive 2H comb filter. 

240. The video synchronizing mechanism of claim 214 wherein 
25 the second sample rate converter comprises a sample rate converter 

module for down-sampling the video samples having the first 
converted rate. 

241. The video synchronizing mechanism of claim 240 wherein 
30 the second sample rate converter further comprises a horizontal 

sync tracker for detecting horizontal syncs and counting the number 



mechanism of claim 214 wherein 
some of the video samples with 
a comb filter for performing a 
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of samples between the horizontal syncs to a sub-sample accuracy, 
and the horizontal sync tracker provides a second adjustment value 
to the sample rate converter module to adjust a second down- 
sampling ratio, which is the ratio between the first converted rate 
5 and the second converted rate. 

242. The video synchronizing mechanism of claim 241 wherein 
the second sample rate converter further comprises a YUV scaler for 
scaling Y, U and V components to the proper amplitudes required by 

10 ITU-R BT. 601. 

243. The video synchronizing mechanism of claim 241 wherein 
the second converted rate is nominally equal to the frequency of a 
display clock, but the second converted rate is locked to a 

15 multiple of a horizontal line rate of the video samples having the 
first converted rate, and not to the display clock. 

244. The video synchronizing mechanism of claim 243 wherein 
the second converted rate is locked to 858 times the horizontal 

20 line rate of the video samples having the first converted rate. 

245. The video synchronizing mechanism of claim 243 wherein 
the second converted rate is locked to 864 times the horizontal 
line rate of the video samples having the first converted rate. 

25 

246. The video synchronizing mechanism of claim 241 wherein 
the horizontal sync tracker counts the number of samples between 
two adjacent horizontal syncs to a sub-sample accuracy. 

30 247. The video synchronizing mechanism of claim 246 wherein 

the horizontal sync tracker counts the number of samples between 
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two adjacent horizontal syncs to an accuracy of l/16 th of a sample 
period. 

248. The video synchronizing mechanism of claim 246 wherein 
5 leading edges of the horizontal syncs are measured to a sub-sample 

accuracy . 

249. The video synchronizing mechanism of claim 248 wherein 
the number of samples with the first converted rate is counted 

10 between two adjacent horizontal syncs. 

250. The video synchronizing mechanism of claim 249 wherein 
the number of samples with the first converted rate between the two 
adjacent horizontal syncs include the number of fractional samples 

15 derived from measuring the leading edges of the horizontal syncs to 
the sub-sample accuracy. 

251. The video synchronizing mechanism of claim 248 wherein 
the leading edges of the horizontal syncs are measured to a sub- 

20 sample accuracy by using interpolation. 

252. The video synchronizing mechanism of claim 241 wherein 
the sample rate converter module interpolates the samples by 33 and 
decimates by 35 + (the second adjustment value) . 

25 

253. The video synchronizing mechanism of claim 241 wherein 
the second sample rate converter further comprises a low pass 
filter, and the low pass filter receives the the second adjustment 
value from the horizontal sync tracker, filters the second 

30 adjustment value, and provides the filtered second adjustment value 
to the sample rate converter module. 
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254. The video synchronizing mechanism of claim 216 wherein 
the time base corrector comprises a FIFO for receiving the output 
of the second sample rate converter as an input and providing an 

5 output that is synchronous to the display clock. 

255. The video synchronizing mechanism of claim 254 wherein 
the time base corrector further comprises a time base corrector 
controller for controlling the FIFO to convert the input with the 

10 second converted rate to the output that is synchronous to the 
display clock. 

256. The video synchronizing mechanism of claim 254 wherein 
the FIFO is filled with the input to approximately one half of its 

15 size prior to starting providing the output. 

257. The video synchronizing mechanism of claim 255 wherein 
the time based corrector controller delays vertical syncs from the 
input by time to fill about half the FIFO with the input. 

20 

258. The video synchronizing mechanism of claim 257 wherein 
the time based corrector controller generates timing signals 
synchronously to the delayed vertical syncs , and the timing signals 
include horizontal syncs. 

25 

259. The video synchronizing mechanism of claim 254 wherein 
the FIFO has a size of a horizontal line. 

260. The video synchronizing mechanism of claim 254 wherein 
30 the FIFO has a size larger than a horizontal line. 
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261. The video synchronizing mechanism of claim 254 wherein 
the FIFO has a size smaller than a horizontal line. 

262. The video synchronizing mechanism of claim 254 wherein 
5 the FIFO is filled with the input to more than half of its size 

prior to starting providing the output. 

263. The video synchronizing mechanism of claim 254 wherein 
the FIFO is filled with the input to less than half of its size 

10 prior to starting providing the output. 

264. The video synchronizing mechanism of claim 214 wherein 
the sampling rate of the stream of video samples is fixed, and the 
stream of video samples is generated using an input sample clock, 

15 which is line locked to an analog video input. 

265. The video synchronizing mechanism of claim 264 wherein 
the first sample rate converter converts the sampling rate of the 
stream of video samples to the first converted rate, which is equal 

20 to four times the chroma sub-carrier frequency. 

266. The video synchronizing mechanism of claim 265 further 
comprising a comb filter, and the comb filter is used to perform a 
luma/chroma separation of the samples with the first converted rate 

25 into demodulated luma and chroma component video signals. 

267. The video synchronizing mechanism of claim 266 wherein 
the second sample rate converter down-samples the demodulated luma 
and chroma component video signals to have the second converted 

30 rate. 
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268. The video synchronizing mechanism of claim 267 wherein 
the second converted rate is 13.5 MHz. 

269. A method of synchronizing video comprising the steps of: 
5 converting a sampling rate of a stream of video 

samples to a first converted rate; 

processing at least some of the video samples having 
the first converted rate; and 

converting the' first converted rate to a second 

10 converted rate. 

270. The method of synchronizing video of claim 269 further 
comprising the step of converting an input video signals from 
analog video signals to digital video signals, wherein the digital 

15 video signals are generated using an input sample clock. 

271. The method of synchronizing video of claim 270 wherein 
the input sample clock is free-running. 

20 272. The method of synchronizing video of claim 270 wherein 

the input sample clock is line locked to the input video signals. 

273. The method of synchronizing video of claim 271 wherein 
the input sample clock has a fixed frequency. 

25 

274. The method of synchronizing video of claim 273 wherein 
the frequency of the input sample clock is fixed at 27 MHz. 

275. The method of synchronizing video of claim 271 wherein 
30 the frequency of the input sample clock is variable. 
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276. The method of synchronizing video of claim 269 wherein 
the first converted rate is four times the chroma sub-carrier 
frequency . 

5 277. The method of synchronizing video of claim 269 wherein 

the step of converting the sampling rate of the stream of video 
samples to the first converted rate comprises the steps of tracking 
phase and frequency of chroma bursts, comparing them against an 
expected pattern, and generating an error signal based on the 
10 result of the comparison. 

278. The method of synchronizing video of claim 277 wherein 
the step of converting the sampling rate of the stream of video 
samples to the first converted rate further comprises the steps of 
15 low pass filtering the error signal and providing the filtered 
error signal as a first adjustment value to a sample rate converter 
to adjust a first down-sampling ratio, which is the ratio between 
the sampling rate and the first converted rate. 

20 279. The method of synchronizing video of claim 277 wherein 

the step of converting the sampling rate of the stream of video 
samples to the first converted rate further comprises the steps of 
low pass filtering the error signal and providing the filtered 
error signal to a voltage controlled oscillator to adjust the 

25 sampling rate. 

280. The method of synchronizing video of claim 269 wherein 
the step of processing at least some of the video samples having 
the first converted rate comprises the step of performing a 
30 luma/chroma separation. 
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281. The method of synchronizing video of claim 280 wherein 
the luma/chroma separation is performed using a comb filter. 

282. The method of synchronizing video of claim 269 wherein 
5 the step of converting the first converted rate to the second 

converted rate comprises the steps of detecting horizontal syncs to 
a sub-sample accuracy, counting the number of samples between the 
horizontal syncs, generating a second adjustment value, and using 
the second adjustment value to adjust a second down-sampling ratio, 
10 which is the ratio between the first converted rate and the second 
converted rate. 

283. The method of synchronizing video of claim 282 wherein 
the step of converting the first converted rate to the second 

15 converted rate further comprises the step of low pass filtering the 
second adjustment value prior to using the second adjustment value 
to adjust the second down-sampling ratio. 

284. The method of synchronizing video of claim 269 further 
20 comprising the steps of storing the output of the second sample 

rate converter in a FIFO, and start outputting the stored output of 
the second sample rate converter from memory when the FIFO is about 
half full. 

25 285. A method of scaling a video image comprising: 

determining whether it will require less memory bandwidth to 
scale the video image before writing the video image to memory or 
after reading the video image from memory; and 

scaling the video image with a scaler engine, 
30 wherein the scaler engine scales the video image either before 

writing the video image to memory or after reading the video image 
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from memory, depending on which operation requires less memory 
bandwidth . 



28 6. The method of scaling a video image of claim 285 wherein 
5 the scaler engine comprises a vertical scaler and a horizontal 
scaler . 



287. The method of scaling a video image of claim 286 wherein 
the vertical scaler performs both downscaling and upscaling in a 
10 vertical axis. 



288. The method of scaling a video image of claim 286 wherein 
the horizontal scaler performs both downscaling and upscaling in a 
horizontal axis. 

28 9. The method of scaling a video image of claim 286 wherein 
the vertical scaler performs downscaling while the horizontal 
scaler performs upscaling. 



20 290. The method of scaling a video image of claim 286 wherein 

the vertical scaler performs upscaling while the horizontal scaler 
performs downscaling . 

291. The method of scaling a video image of claim 286 wherein 
25 the vertical scaler performs upscaling while the horizontal scaler 
performs upscaling . 



292. The method of scaling a video image of claim 286 wherein 
the vertical scaler performs downscaling while the horizontal 
30 scaler performs downscaling. 
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293. The method of scaling a video image of claim 286 further 
comprising the step of programming the horizontal scaler for 
upscaling . 

5 294. The method of scaling a video image of claim 286 further 

comprising the step of programming the horizontal scaler for 
downscaling . 

295. The method of scaling a video image of claim 286 further 
10 comprising the step of programming the vertical scaler for 
upscaling . 

2 96. The method of scaling a video image of claim 28 6 further 
comprising the step of programming the vertical scaler for 
15 downscaling. 

297. A video scaler comprising: 

a scaler engine for performing both upscaling and 
downscaling of video images, 
20 wherein the scaler engine processes the video images 

either before writing the video images to memory or after reading 
the video images from memory. 

298. The video scaler of claim 297 further comprising a 
25 plurality of line buffers for providing the video images to the 

scaler engine. 

299. The video scaler of claim 297 wherein the scaler engine 
comprises a horizontal scaler and a vertical scaler. 

30 
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300. The video scaler of claim 299 wherein the horizontal 
scaler is a programmable filter. 



301. The video scaler of claim 299 wherein the horizontal 
scaler is a multi-tap polyphase filter. 

302. The video scaler of claim 299 wherein the horizontal 
scaler is a filter having eight taps. 

303. The video scaler of claim 300 further comprising a 
horizontal coefficient memory for storing horizontal filter 
coefficients for the programmable filter. 



304. The video scaler of claim 302 further comprising an 
eight-tap shift register for providing input to the eight taps of 
the filter. 



305. The video scaler of claim 299 wherein the vertical scaler 
is a programmable filter. 

306. The video scaler of claim 299 wherein the vertical scaler 
is a multi-tap polyphase filter. 

307. The video scaler of claim 299 wherein the vertical scaler 
is a filter having four taps. 



308. The video scaler of claim 305 further comprising a 
vertical coefficient memory for storing vertical filter 
coefficients for the programmable filter. 
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309. The video scaler of claim 307 further comprising a 
plurality of line buffers, wherein the plurality of line buffers 
comprise three line buffers, and inputs to the four taps of the 
filter are provided by the three line buffers and an incoming video 

5 image. 

310. A method of compositing a plurality of graphics images 
and video comprising the steps of: 

blending the plurality of graphics images into a blended 
10 graphics image; 

combining a plurality of alpha values into a plurality of 
composite alpha values; and 

blending the blended graphics image and the video using 
the plurality of composite alpha values. 

15 

311. The method of compositing a plurality of graphics images 
and video of claim 310 wherein the plurality of graphics images are 
blended together using the plurality of alpha values. 

20 312. The method of compositing a plurality of graphics images 

and video of claim 311 wherein each of the plurality of graphics 
images is associated with one of the plurality of alpha values. 

313. The method of compositing a plurality of graphics images 
25 and video of claim 312 wherein each of the plurality of graphics 
images includes a plurality of pixels, and each of the plurality of 
pixels is associated with the alpha value that is associated with 
the graphics image that includes that pixel. 

30 314. The method of compositing a plurality of graphics images 

and video of claim 311 wherein each of the plurality of graphics 
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images includes a plurality of pixels, and each of the plurality of 
pixels is associated with one of the plurality of alpha values. 

315. The method of compositing a plurality of graphics images 
5 and video of claim 311 wherein each of the plurality of graphics 

images includes a plurality of pixels, and the value of each of the 
plurality of pixels is one of the plurality of alpha values. 

316. The method of compositing a plurality of graphics images 
10 and video of claim 314 wherein the plurality of graphics images are 

organized into layers, each of the plurality of graphics images 
being associated a layer, from the back most layer to the front 
most layer. 

15 317. The method of compositing a plurality of graphics images 

and video of claim 316 wherein the step of blending the plurality 
of graphics images into a blended graphics image comprises the step 
of blending the graphics image on a second layer on top of the 
graphics image on a first layer to generate an intermediate image 

20 having a plurality of pixels. 

318. The method of compositing a plurality of graphics images 
and video of claim 317 wherein the step of blending the plurality 
of graphics images into a blended graphics image further comprises 

25 the step of blending a graphics image that has not been blended 
yet, on top of the intermediate image to generate a new 
intermediate image . 

319. The method of compositing a plurality of graphics images 
30 and video of claim 318 wherein the step of blending the plurality 

of graphics images into a blended graphics image further comprises 
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the step of repeating the step of blending a graphics image that" 
has not been blended yet, on top of the intermediate image to 
generate a new intermediate image, until the graphics image on all 
of the layers have been blended. 

5 

320. The method of compositing a plurality of graphics images 
and video of claim 317 wherein the step of blending the graphics 
image on a second layer on top of the graphics image on a first 
layer to generate an intermediate image having a plurality of 

10 pixels comprises the step of blending each of the plurality of 
pixels of the graphics image on the first layer with a 
corresponding one of the plurality of pixels of the graphics image 
on the second layer, using the plurality of alpha values associated 
with the plurality of pixels of the graphics image on the second 

15 layer. 

321. The method of compositing a plurality of graphics images 
and video of claim 320 wherein the step of blending each of the 
plurality of pixels of the graphics image on the first layer with 

20 a corresponding one of the plurality of pixels of the graphics 
image on the second layer comprises the steps of multiplying each 
of the pixels of the graphics image on the first layer by (1-alpha 
value) of the alpha value associated with the corresponding one of 
the plurality of pixels of the graphics image on the second layer, 

25 multiplying each of the pixels of the graphics image on the second 
layer by the associated alpha value, and adding the products of the 
two multiplications . 

322. The method of compositing a plurality of graphics images 
30 and video of claim 318 wherein the step of blending a graphics 

image that has not been blended yet, on top of the intermediate 
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image to generate a new intermediate image comprises the step of 
blending each of the plurality of pixels of the intermediate image 
with a corresponding one of the plurality of pixels of the graphics 
image that has not been blended yet, using the plurality of alpha 
5 values associated with the plurality of pixels of the graphics 
image that has not been blended yet. 

323. The method of compositing a plurality of graphics images 
and video of claim 322 wherein the step of blending each of the 

10 plurality of pixels of the intermediate image with a corresponding 
one of the plurality of pixels of the graphics image that has not 
been blended yet, comprises the steps of multiplying each of the 
pixels of the intermediate image by (1-alpha value) of the alpha 
value associated with the corresponding one of the plurality of 

15 pixels of the graphics image that has not been blended yet, 
multiplying each of the pixels of the graphics image that has not 
been blended yet, by the associated alpha value, and adding the 
products of the two multiplications. 

20 324. The method of compositing a plurality of graphics images 

and video of claim 314 wherein the step of combining a plurality of 
alpha values into a plurality of composite alpha values comprises 
the step of multiplying (1-alpha value) associated with each of the 
plurality of pixels of a graphics image with (1-alpha value) 

25 associated with a corresponding pixel of each of all other graphics 
images to generate each of the plurality of composite alpha values. 

325. The method of compositing a plurality of graphics images 
and video of claim 316 wherein the step of combining a plurality of 
30 alpha values into a plurality of composite alpha values comprises 
the step of multiplying (1-alpha value) associated with each of the 
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plurality of pixels of the graphics image on a first layer by ( 1 - 
alpha value) associated with each of the plurality of pixels of the 
graphics image on a second layer to generate a plurality of 
intermediate alpha values. 

5 

326. The method of compositing a plurality of graphics images 
and video of claim 325 wherein the step of combining a plurality of 
alpha values into a plurality of composite alpha values further 
comprises the step of multiplying each of the plurality of 

10 intermediate alpha values with (1-alpha value) associated with each 
of the plurality of pixels of the graphics image whose alpha values 
previously have not been multiplied into the plurality of 
intermediate alpha values, to newly generate a plurality of 
intermediate alpha values. 

15 

327. The method of compositing a plurality of graphics images 
and video of claim 326 wherein the step of combining a plurality of 
alpha values into a plurality of composite alpha values further 
comprises the step of repeating the step of multiplying each of the 

20 plurality of intermediate alpha values with (1-alpha value) 
associated with each of the plurality of pixels of the graphics 
image whose alpha values previously have not been multiplied into 
the plurality of intermediate alpha values, to newly generate a 
plurality of intermediate alpha values, until alpha values of all 

25 graphics images have been multiplied, 

and wherein the newly generated plurality of intermediate 
alpha values, after the alpha values of all graphics images have 
been multiplied, are the plurality of composite alpha values. 

30 
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328. The method of compositing a plurality of graphics images 
and video of claim 310 further comprising filtering the blended 
graphics image prior to blending the blended graphics image with 
the video. 

5 

329. The method of compositing a plurality of graphics images 
and video of claim 328 wherein step of filtering includes vertical 
scaling . 

10 330. The method of compositing a plurality of graphics images 

and video of claim 328 wherein step of filtering includes 
horizontal scaling . 

331. The method of compositing a plurality of graphics images 
15 and video of claim 328 wherein step of filtering includes anti- 
flutter filtering . 

332. The method of compositing a plurality of graphics images 
and video of claim 310 wherein the video comprises passthrough 

20 video and a video window. 



333. The method of compositing a plurality of graphics images 
and video of claim 332 further comprising the step of blending 
background color with the video. 

334. The method of compositing a plurality of graphics images 
and video of claim 333 wherein passthrough video is blended with 
the background color to generate an intermediate video image using 
alpha values. 
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335. The method of compositing a plurality of graphics images 
and video of claim 334 wherein the video window is blended with the 
intermediate video image using alpha values to generate a blended 
video image. 

5 

336. The method of compositing a plurality of graphics images 
and video of claim 335 wherein the blended video image is blended 
with the blended graphics image using the plurality of composite 
alpha values. 

10 

337. The method of compositing a plurality of graphics images 
and video of claim 336 wherein the blended video image includes a 
plurality of video pixels and the blended graphics image includes 
a plurality of graphics pixels, and each of the plurality of 

15 composite alpha values is associated with one of the plurality of 
the video pixels and one of the plurality of the graphics pixels. 

338. The method of compositing a plurality of graphics images 
and video of claim 337 wherein the step of blending the blended 

20 graphics image and the video using the plurality of composite alpha 
value comprises the steps of multiplying each of the plurality of 
video pixels by the associated one of the plurality of the 
composite alpha values, and each of the plurality of the graphics 
pixels is added to the product of the associated one of the 

25 plurality of video pixels and the associated one of the plurality 
of composite alpha values. 

339. The method of compositing a plurality of graphics images 
and video of claim 310 wherein the step of blending the plurality 

30 of graphics images into a blended graphics image comprises blending 
of two or more graphics images simultaneously at a time. 
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340. A graphics display system comprising: 

a display engine for blending a plurality of 
graphics images into a blended graphics image and combining a 
5 plurality of alpha values into a plurality of composite alpha 
values; and 

a video compositor for blending the blended graphics 
image with video. 

10 341. The graphics display system of claim 340 wherein the 

video compositor also blends a background color. 

342. The graphics display system of claim 341 wherein the 
video includes passthrough video and a video window. 

15 

343. The graphics display system of claim 340 wherein the 
display engine blends two or more graphics images at a time to 
generate the blended graphics image. 

20 344. The graphics display system of claim 340 wherein each of 

the plurality of alpha values is associated with one of the 
plurality of graphics images. 

345. The graphics display system of claim 340 wherein each of 
25 the plurality of graphics images includes a plurality of graphics 

pixels, and each of the plurality of alpha values is associated 
with one of the plurality of graphics pixels. 

346. The graphics display system of claim 345 wherein the 
30 plurality of graphics images is organized into layers, wherein each 

of the plurality of graphics images is on and associated with a 
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layer that is different from each other and the layers are stacked 
from the back most layer to the front most layer. 

347. The graphics display system of claim 346 wherein each of 
5 the plurality of graphics pixels of the graphics image on the back 
most layer is multiplied by (1-alpha value) of the alpha value 
associated with a corresponding one of the plurality of graphics 
pixels of the graphics image on the layer immediately in front of 
the back most layer, each of the plurality of graphics pixels of 
10 the graphics image on the layer immediately in front of the back 
most layer is multiplied by the associated alpha value, and the 
products of two multiplications are added to generate each of the 
plurality of graphics pixels of an intermediate graphics image. 

15 348. The graphics display system of claim 347 wherein each of 

the plurality of graphics pixels of the intermediate graphics image 
is multiplied by (1-alpha value) of the alpha value associated with 
a corresponding one of the plurality of graphics pixels of the 
graphics image on the layer immediately in front of all layers for 

20 which the associated graphics image has been blended, each of the 
plurality of graphics pixels of the graphics image, on the layer 
immediately in front of all layers for which the associated 
graphics image has been blended, is multiplied by the associated 
alpha value, and the products of two multiplications are added to 

25 generate each of the plurality of graphics pixels of a new 
intermediate graphics image. 

349. The graphics display system of claim 348 wherein the 
plurality of graphics pixels of a new intermediate graphics image 
30 are repeatedly generated until each of the plurality of graphics 
pixels of the intermediate graphics image is multiplied by (1-alpha 
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value) of the alpha value associated with a corresponding one of 
the plurality of graphics pixels of the graphics image on the front 
most layer, each of the plurality of the graphics pixels of the 
graphics image on the front most layer has been multiplied with the 
5 associated alpha value, and the products of the two multiplications 
are added to generate each of the plurality of graphics pixels of 
the new intermediate graphics image, and 

wherein the new intermediate graphics image is the 
blended graphics image after the graphics image on the front most 
10 layer has been blended. 

350. The graphics display system of claim 346 wherein (1-alpha 
value) of the alpha value associated with each of the plurality of 
the pixels of the graphics image on the back most layer is 
15 multiplied by (1-alpha value) associated with each of the plurality 
of the pixels of the graphics image on the layer immediately in 
front of the back most layer to generate each of the plurality of 
intermediate alpha values. 

20 351. The graphics display system of claim 350 wherein each of 

the plurality of intermediate alpha values is multiplied by (1- 
alpha) of the alpha value associated with each of the plurality of 
the pixels of the graphics image on the layer that is immediately 
in front of all layers for which associated plurality of alpha 

25 values have been multiplied into the plurality of intermediate 
alpha values, to newly generate the plurality of intermediate alpha 
values . 

352. The graphics display system of claim 351 wherein the 
30 plurality of intermediate alpha values are newly generated 
repeatedly until the plurality of alpha values associated with the 
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plurality of pixels of the graphics image on the front most layer 
have been multiplied into the plurality of intermediate alpha 
values, and 

wherein the plurality of intermediate alpha values after 
5 the plurality of alpha values associated with the plurality of 
pixels of the graphics image on the front most layer are the 
plurality of composite alpha values. 

353. The graphics display system of claim 342 wherein the 
10 video compositor blends passthrough video with the background color 

to generate an intermediate video image:. 

354. The graphics display system of claim 343 wherein the 
video compositor blends the intermediate video image with the video 

15 window to generate a blended video image having a plurality of 
video pixels. 

355. The graphics display system of claim 354 wherein the 
blended graphics image includes a plurality of graphics pixels, 

20 each of the plurality of video pixels is associated with one of the 
plurality of composite alpha values and one of the plurality of 
graphics pixels, and video compositor blends the blended video 
image and the blended graphics by multiplying each of the plurality 
of video pixels by the associated one of the plurality of composite 

25 alpha values and adding the associated one of the plurality of 
graphics pixels. 

356. A method of compositing graphics images using alpha blend 
values comprising the steps of: 

30 blending each line of a second graphics image on top of 

a corresponding line of a first graphics image using alpha values, 
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if the line is neither a first line nor a last line of the second 
graphics image; and 

blending the first line and the last line of the second 
graphics image on top of the corresponding lines of the first 
5 graphics image using about 0.5 * alpha blend values, 

wherein the second graphics image includes a plurality 
of pixels, each pixel being associated with an alpha blend value, 
and the first graphics image includes a plurality of pixels. 

10 357. The method of compositing graphics images using alpha 

blend values of claim 356 wherein the step of blending each line 
of a second graphics image on top of a corresponding line of a 
first graphics image, if the line is neither a first line nor a 
last line of the second graphics image, comprises the steps of 

15 multiplying each of the plurality of pixels of the first graphics 
image by (1-alpha blend value) of the alpha blend value 
associated with a corresponding pixel of the second graphics 
image, multiplying the corresponding pixel of the second graphics 
image with the associated alpha blend value, and adding the 

20 products of the two multiplications. 

358. The method of compositing graphics images using alpha 
blend values of claim 356 wherein the step of blending the first 
line and the last line of the second graphics image on top of the 

25 corresponding lines of the first graphics image using about 0.5 * 
alpha blend values comprises the steps of multiplying each of the 
plurality of pixels of the first graphics image by (1 - 0.5 * alpha 
blend value) of the alpha blend value associated with a 
corresponding pixel of the second graphics image, multiplying the 

30 corresponding pixel of the second graphics image with the 
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associated alpha blend value * 0.5, and adding the products of the" 
two multiplications . 

359. A graphics filter comprising: 
5 means for scaling graphics; and 

means for performing anti-flutter filtering, wherein the 
means for performing anti-flutter filtering is same as the means 
for scaling video. 

10 360. The graphics filter of claim 359 wherein the means for 

scaling graphics and the means for performing anti-flutter 
filtering include a polyphase filter. 

361. The graphics filter of claim 360 wherein the polyphase 
15 filter is programmable. 

362. The graphics filter of claim 359 wherein the means for 
scaling graphics scales the graphics vertically. 

20 363. The graphics filter of claim 359 wherein the means for 

scaling graphics scales the graphics horizontally. 

364. The graphics filter of claim 359 wherein the means for 
scaling graphics and the means for performing anti-flutter 

25 filtering include a filter having four taps. 

365. The graphics filter of claim 361 wherein the polyphase 
filter has four taps. 



197 



WO 00/28518 



PCT/US99/26484 - 



366. The graphics filter of claim 359 wherein the graphics 
filter operates in a field mode wherein every other display line is 
processed during filtering. 

5 367. The graphics filter of claim 359 wherein the graphics 

filter operates in a frame mode wherein every display line is 
processed during filtering. 

368. The graphics filter of claim 365 wherein inputs to the 
10 four taps of the polyphase filter are provided by four line 

buffers . 

369. The graphics filter of claim 361 further comprising 
horizontal coefficient memory for programming the polyphase filter. 

15 

370. The graphics filter of claim 361 further comprising 
vertical coefficient memory for programming the polyphase filter. 

371. A method of performing anti-flutter filtering and 
20 graphics scaling comprising the steps of: 

providing a plurality of display lines to a graphics 
filter; and 

performing graphics scaling and anti-flutter filtering 
simultaneously using the graphics filter. 

25 

372. The method of performing anti-flutter filtering and 
graphics scaling of claim 371 wherein the graphics filter includes 
a polyphase filter. 
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373. The method of performing anti-flutter filtering and 
graphics scaling of claim 372 wherein the polyphase filter is a 
four tap filter. 

5 374. The method of performing anti-flutter filtering and 

graphics scaling of claim 371 wherein graphics scaling comprises 
vertical scaling. 

375. The method of performing anti-flutter filtering and 
10 graphics scaling of claim 371 wherein graphics scaling comprises 

horizontal scaling . 

376. The method of performing anti-flutter filtering and 
graphics scaling of claim 371 where in the step of providing a 

15 plurality of display lines to a graphics filter comprises the steps 
of compositing graphics images into a plurality of line buffers, 
and providing blended graphics in the plurality of line buffers to 
be filtered and scaled. 

20 377. The method of performing anti-flutter filtering and 

graphics scaling of claim 376 wherein contents of four line buffers 
are provided for filtering and scaling at a time. 

378. The method of performing anti-flutter filtering and 
25 graphics scaling of claim 377 wherein graphics images are 
composited to create blended graphics in one or more of other line 
buffers while the contents of the four line buffers are being 
provided for filtering and scaling. 

30 379. A unified memory system comprising: 

a memory that is shared by a plurality of devices; and 
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a memory request arbiter coupled to the memory, wherein 
the memory request arbiter performs real time scheduling of memory 
requests from different devices having different priorities, the 
unified memory system assures real time scheduling of tasks, some 
of which do not inherently have pre-determined periodic behavior 
and provides access to memory by requesters that are sensitive to 
latency and do not have determinable periodic behavior. 

380. The unified memory system of claim 379 wherein a minimum 
interval between subsequent accesses by one or more tasks is 
enforced. 

381. The unified memory system of claim 379 further comprising 
one or more block out timers coupled between respective one or more 
of the plurality of devices and the memory request arbiter, and 
each block out timer is used to enforce a minimum interval between 
subsequent accesses by the respective one of the plurality of 
devices . 

382. The unified memory system of claim 381 wherein the 
respective one or more of the plurality of devices include a CPU. 

383. The unified memory system of claim 381 wherein the 
respective one or more of the plurality of devices make high 
priority service requests through their respective block out 
timers . 

384. The unified memory system of claim 383 wherein each block 
out timer blocks out the high priority service request made by the 
respective one of the plurality of devices while the block out 
timer is running until the block out timer times out. 
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385. The unified memory system of claim 384 wherein each 
block out timer is started when the respective one of the plurality 
of devices makes the high priority service request 

5 

38 6. The unified memory system of claim 384 wherein each block 
out timer is started when the high priority service request made by 
the respective one of the plurality of devices is serviced. 

10 387. The unified memory system of claim 384 wherein each block 

out timer is started some time between the time the respective one 
of the plurality of devices makes the high priority service request 
and the time when the high priority service request is serviced. 

15 388. The unified memory system of claim 381 wherein a block 

out period of at least one of the block out timers is programmable. 

38 9. The unified memory system of claim 381 further comprising 
a round robin server for handling low priority tasks, wherein one 

20 or more of the plurality of devices that are coupled to their 
respective block out timers are also coupled to the round robin 
server as low priority tasks, and the round robin server requests 
service to the memory request arbiter for one of the low priority 
tasks coupled to the round robin server at a time in a round robin 

25 manner. 

390. The unified memory system of claim 389 wherein the one or 
more of the plurality of devices that are coupled to their 
respective block out timers is handled as one of the low priority 
30 tasks whenever their respective block out timers are running. 
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391. The unified memory system of claim 379 further comprising 
dual memory controllers, the dual memory controllers includes a 
first memory controller and a second memory controller, the memory 
request arbiter includes a first arbiter coupled to the first 
memory controller and a second arbiter coupled to the second memory 
controller, wherein the first arbiter and the second arbiter 
perform real time scheduling of memory requests separately and 
independently of each other. 



392. A method of designing real time scheduling comprising the 
steps of: 

running a critical instant analysis; 

ordering periods of different tasks from the shortest to 
the longest; 

15 assigning priorities based on the order in accordance to 

the duration of the periods; 

selecting tasks that are non-periodic but requires 
expedited servicing, assigning high priorities to them, and 
imposing a minimum interval between successive accesses by these 

20 tasks; and 

assigning low priority to non-periodic tasks, that do not 
require expedited servicing, to be serviced in a round robin 
manner . 



25 393. The method of designing real time scheduling of claim 392 

wherein the step of running a critical instant analysis comprises 
the steps of assuming all tasks request service at the critical 
instant, assuming a task is being serviced at the critical instant, 
and determining whether or not all tasks can be serviced within a 

30 period of each task. 
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394. The method of designing real time scheduling of claim 392 - 
wherein the design for real time scheduling is re-evaluated if the 
critical instant analysis fails. 

5 395. The method of designing real time scheduling of claim 392 

wherein the minimum interval between successive accesses by the 
high priority tasks that are non-periodic but requires expedited 
servicing is imposed by coupling a block out timer between each of 
these tasks and a memory request' arbiter, such that high priority 
10 service request by each these tasks is blocked out while the block 
out timer coupled to the task is running. 

39 6. The method of designing real time scheduling of claim 395 
wherein the block out timer is designed to start running upon 
15 making of the high priority service request by the coupled task. 

397. The method of designing real time scheduling of claim 395 
wherein the block out timer is designed to start running upon 
servicing of the high priority service request made by the coupled 

20 task. 

398. The method of designing real time scheduling of claim 397 
wherein the block out timer is designed to start running some time 
between the time the high priority service request is made by the 

25 coupled task and that high priority service request is serviced. 

399. The method of designing real time scheduling of claim 395 
wherein the high priority tasks, that are non-periodic but requires 
expedited servicing, are also coupled to a round robin server that 

30 handles service requests from these high priority tasks as low 
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priority requests in a round robin manner while respective block 
out timer is running. 

4 00. The method of designing real time scheduling of claim 392 
wherein real time scheduling is implemented independently to first 
and second arbiters. 

401. The method of designing real time scheduling of claim 400 
wherein the first arbiter is coupled to a first memory controller 
and the second arbiter is coupled to a second memory controller, 
and wherein the first and second memory controllers control first 
and second memory spaces that are contiguous to each other. 

402. A graphics accelerator comprising: 

a memory for graphics data, the graphics data including 
pixels; and 

a coprocessor for performing vector type operations on a 
plurality of components of one pixel of the graphics data. 

403. The graphics accelerator of claim 402 wherein the memory 
includes a data SRAM. 

404. The graphics accelerator of claim 402 further comprising 
a direct memory access (DMA) engine for loading the graphics data 
from memory through loading operations and transferring processed 
graphics data to the memory through storing operations. 

405. The graphics accelerator of claim 402 wherein the 
coprocessor processes the plurality of components of each pixel in 
parallel as three elements of a vector. 
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406. The graphics accelerator of claim 405 wherein the 
plurality of components of each pixel comprise R, G and B 
components of RGB formatted graphics data. 

407. The graphics accelerator of claim 406 wherein the pixels 
are in an RGB 16 format. 



408. The graphics accelerator of claim 407 wherein the R 
component has five bits, the G component has six bits and the B 
component has 5 bits. 



409. The graphics accelerator of claim 407 wherein the 
graphics data is organized into 32-bit words, and each 32-bit word 
includes two pixels having RGB16 format. 



410. The graphics accelerator of claim 409 wherein the two 
pixels are respectively selected by two special load instructions. 

411. The graphics accelerator of claim 410 wherein the two 
special load instructions are for loading a left one and a right 
one of the two pixels, respectively. 

412. The graphics accelerator of claim 408 wherein the 
coprocessor comprises an input register. 

413. The graphics accelerator of claim 412 wherein the R, G 
and B components are expanded into 8-bit components through zero 
expansion when loaded into the input register. 
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414. The graphics accelerator of claim 405 wherein the 
plurality of components of each pixel comprise Y, U and V 
components of YUV formatted graphics data, and 

wherein the Y, U and V components are also referred to as Y, 
Cr and Cb components, respectively, of YCrCb formatted graphics 
data . 

415. The graphics accelerator of claim 414 wherein the pixels 
are in a YUV 4:2:2 format. 

416. The graphics accelerator of claim 415 wherein the pixels 
are organized into 32-bit words and each 32-bit word contains two 
pixels . 

417. The graphics accelerator of claim 416 wherein the two 
pixels in each 32-bit word is organized in a YUYV format, each of 
the first Y component, the U component, the second Y component, and 
the V component occupies eight bits, a first one of the two pixels 
is comprised of a first Y component, the U component and the V 
component, and a second one of the two pixels is comprised of the 
second Y component, the U component and the V component. 

418. The graphics accelerator of claim 416 wherein the two 
pixels are respectively selected by two special load instructions. 

419. The graphics accelerator of claim 418 wherein the two 
special load instructions are for extracting a first one and a 
second one of the two pixels, respectively. 

420. The graphics accelerator of claim 405 wherein the 
coprocessor has an instruction set that includes a special 
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instruction for comparing between each element of a pair of 3- 
element vectors. 

421. The graphics accelerator of claim 420 wherein the 
coprocessor further comprises a result register, and results of the 
three comparisons are stored in the result register. 

422. The graphics accelerator of claim 421 wherein the results 
of the three comparisons are used together during a single 
conditional branch operation. 

423. The graphics accelerator of claim 420 wherein the special 
instruction is for a greater-than-or-equal-to operation. 

424. The graphics accelerator of claim 404 wherein the DMA 
engine moves data between the memory and an external memory at the 
same time the graphics accelerator is using the memory for its load 
and store operations. 

425. The graphics accelerator of claim 424 wherein the 
external memory is a unified memory that is shared by a graphics 
display system, a CPU and other peripheral devices. 

426. The graphics accelerator of claim 404 wherein the DMA 
engine includes a queue to hold a plurality of DMA commands. 

427. The graphics accelerator of claim 426 wherein the 
plurality of DMA commands are executed in the order they are 
received. 
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428. The graphics accelerator of claim 426 wherein the queue 
comprises a mechanism that allows the graphics accelerator to 
determine when all the DMA commands have been completed. 

5 429. The graphics accelerator of claim 426 wherein the queue 

is four deep for storing up to four DMA commands. 

430. The graphics accelerator of claim 404 wherein the 
graphics accelerator is working on operands and producing outputs 

10 for one set of pixels, while the DMA engine is bringing in operands 
for a future set of pixel operations. 

431. A method of processing graphics comprising the steps of: 

loading graphics data into a graphics accelerator 
15 having a coprocessor, the graphics data including pixels, each 
pixel having a plurality of components; and 

performing vector type operations on the plurality 
of components of each pixel of graphics data using the coprocessor. 

20 432. The method of processing graphics of claim 431 wherein 

the plurality of components comprises R, G and B components of RGB 
formatted graphics data. 

433. The method of processing graphics of claim 432 wherein 
25 the pixels of the graphics data are in an RGB16 format. 

434. The method of processing graphics of claim 433 further 
comprising the step of organizing the graphics data into 32-bit 
words, wherein each 32-bit word includes two pixels having RGB 16 

30 format. 
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435. The method of processing graphics of claim 434 further- 
comprising the step of selecting each of the two pixels with one of 
two special load instructions. 

5 436. The method of processing graphics of claim 435 wherein 

the step of selecting each of the two pixels comprises loading a 
left one of the two pixels. 

437. The method of processing graphics of claim 435 wherein 
10 the step of selecting each of the two pixels comprises loading a 

right one of the two pixels. 

438. The method of processing graphics of claim 431 wherein 
each of the plurality of pixels of graphics data comprises Y, U and 

15 V components of YUV formatted graphics data. 

439. The method of processing graphics of claim 438 wherein 
the pixels are in a YUV 4:2:2 format. 

20 440. The method of processing graphics of claim 439 further 

comprising the step of organizing the pixels into 32-bit words, 
wherein each 32-bit word contains two pixels. 

441. The method of processing graphics of claim 440 wherein 
25 the step of organizing the pixels into 32-bit words comprises 
organizing each of the two pixels into a YUYV format, wherein each 
of the first Y component, the U component, the second Y component 
and the V component occupies eight bits, a first one of the two 
pixels is comprised of a first Y component, the U component and the 
30 V component, and a second one of the two pixels is comprised of the 
second Y component, the U component and the V component. 
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442. The method of processing graphics of claim 441 further 
comprising the step of selecting each of the two pixels with one of 
two special load instructions. 

5 

443. The method of processing graphics of claim 442 wherein 
the step of selecting each of the two pixels comprises loading the 
first one of the two pixels. 

10 444. The method of processing graphics of claim 443 wherein 

the step of selecting each of the two pixels comprises loading the 
second one of the two pixels. 

445. The method of processing graphics of claim 431 further 
15 comprising the step of comparing between each element of a pair of 

3-element vectors, wherein each element of the 3-element vector is 
one of three components of each pixel. 

446. The method of processing graphics of claim 445 wherein 
20 the three components of each pixel are R, G and B components. 

447. The method of processing graphics of claim 445 wherein 
the three components of each pixel are Y, U and V components. 

25 448. The method of processing graphics of claim 445 wherein 

the coprocessor includes a result register, and the method further 
comprising the step of storing results' of the three comparisons in 
the result register. 
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449. The method of processing graphics of claim 448 further 
comprising the step of performing a single conditional branch 
operation using the results of the three comparisons. 

5 450. The method of processing graphics of claim 445 wherein 

the step of comparing between each element of a pair of 3-element 
vectors comprises the step of performing a greater-than-or-equal-to 
operation between each element of a pair of 3-element vectors. 

10 451. The method of processing graphics of claim 431 wherein 

the graphics accelerator includes a memory for loading the graphics 
data further comprising the step of moving data between the memory 
and an external memory using a direct memory access (DMA) engine at 
the same time the graphics accelerator is using the memory for its 

15 load and store operations. 

452. The method of processing graphics of claim 451 wherein 
the memory is a data SRAM. 

20 453. The method of processing graphics of claim 451 wherein 

the external memory is a unified memory that is shared by a 
graphics display system, a CPU and other peripheral devices. 

454. The method of processing graphics of claim 451 wherein 
25 the DMA engine includes a queue for holding a plurality of DMA 

commands . 

455. The method of processing graphics of claim 454 further 
comprising the step of determining whether all the DMA commands 

30 have been completed. 
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456. The method of processing graphics of claim 454 further 
comprising the step of receiving the plurality of DMA commands. 

457. The method of processing graphics of claim 456 further 
5 comprising the step of executing the plurality of DMA commands in 

the order they are received. 

458. The method of processing graphics of claim 454 wherein 
the queue is four deep for storing up to four DMA commands. 

10 

459. The method of processing graphics of claim 431 further 
comprising the step of bringing in operands for a future set of 
pixel operations using a direct memory access (DMA) engine while 
the graphics accelerator is working on operands and producing 

15 outputs for one set of pixels. 
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